| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1260 人关注过本帖
标题:[求助]这个功能该如何实现,给点思路
取消只看楼主 加入收藏
静思
Rank: 3Rank: 3
来 自:沈阳
等 级:新手上路
威 望:8
帖 子:630
专家分:0
注 册:2006-2-28
收藏
 问题点数:0 回复次数:3 
[求助]这个功能该如何实现,给点思路
编写一个函数Int MajorityElement(int array[],int n);
该函数返回数组array中的多数元素。多数元素是指在占绝对多数(至少51%)的一个值。如果多数元素不存在,那么返回常量NoMajorityElement,该函数必须满足下面的条件:
1. 必须以O(N)时间运行。
2. 必须使用O(1)的附加空间。换句话说,可用个别的临时变量,而不可以使用任何的临时数组。并且不能使用递归解决,这是因为随着递归层数加深,会需要空间来存储栈帧。
3. 不能改变数组中的任何元素的值。

要是可以给一个临时数组,这个问题就好办了,关键是只能用到O(1)的附加空间。
大家看能不能给点思路

搜索更多相关主题的帖子: 思路 元素 array 函数 
2007-10-11 22:28
静思
Rank: 3Rank: 3
来 自:沈阳
等 级:新手上路
威 望:8
帖 子:630
专家分:0
注 册:2006-2-28
收藏
得分:0 
以下是引用cobby在2007-10-12 9:12:59的发言:
好像要求很苛刻的样子,问一下,参数n干嘛用的?一起想下呵

n代表数组array的元素个数


英者自知,雄者自胜
2007-10-12 11:14
静思
Rank: 3Rank: 3
来 自:沈阳
等 级:新手上路
威 望:8
帖 子:630
专家分:0
注 册:2006-2-28
收藏
得分:0 

楼上有能在线性时间内完成数组排序的算法吗?


英者自知,雄者自胜
2007-10-12 15:23
静思
Rank: 3Rank: 3
来 自:沈阳
等 级:新手上路
威 望:8
帖 子:630
专家分:0
注 册:2006-2-28
收藏
得分:0 
楼上的不知道有没有什么好方法

英者自知,雄者自胜
2007-10-12 15:27
快速回复:[求助]这个功能该如何实现,给点思路
数据加载中...
 
   



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

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