| 网站首页 | 业界新闻 | 小组 | 交易 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
共有 2238 人关注过本帖
标题:[求助]英雄树,用c语言实现
只看楼主 加入收藏
it明少
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2016-4-20
结帖率:0
  已结贴   问题点数:20  回复次数:2   
[求助]英雄树,用c语言实现
Description

有n个数字,其中有一个数字的出现次数超过总个数的一半,这个数称之为英雄数。
例如,n=12,整数序列5,5,5,5,5,5,1,2,3,4,5,6,其中的英雄数为5。

对于给定的n个整数组成的序列,请使用数据结构堆栈,设计出一个时间复杂度为O(n)算法,计算出序列中的英雄数。

Input

由键盘提供输入数据。文件的第1行有1个正整数n<=1000000,表示整数序列有n个整数。第2行是整数序列,整数大小都在32位有符号整型内,数字之间以一个空格隔开。
输入数据保证必然存在一个数字,其出现次数超过总个数的一半。

Output

程序运行结束时,将指定序列的英雄数输出到屏幕上。

Sample Input


12
5 5 5 5 5 5 1 2 3 4 5 6

Sample Output


5

Source
搜索更多相关主题的帖子: 正整数  c语言  英雄  键盘  
2016-04-20 08:52
it明少
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2016-4-20
  得分:0 
2016-04-20 08:52
azzbcc
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:江西财经大学
等 级:贵宾
威 望:81
帖 子:3293
专家分:12919
注 册:2012-11-4
  得分:20 
大致思路是这样。

程序代码:
#include <ext/hash_map>
#include <iostream>
#include <stdint.h>

using namespace std;
using namespace __gnu_cxx;

int main(int argc, char *argv[])
{
    int tmp, n;
    hash_map<int, int> map;

    cin >> n;
    for (int i = 0;i != n;i++)
    {
        cin >> tmp;
        map[tmp]++;
    }
    hash_map<int, int>::const_iterator iter;
    for (iter = map.begin();iter != map.end();++iter)
    {
        if (iter->second > n / 2)
        {
            cout << iter->first << endl;
        }
    }
    return 0;
}



[fly]存在即是合理[/fly]
2016-04-21 11:01







关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.042420 second(s), 8 queries.
Copyright©2004-2019, BCCN.NET, All Rights Reserved