多数元素

定义:序列中的多数元素是指在一个元素个数为n的序列中,多数元素出现次数大于[n/2].

这题解题思路有很多,可以暴力破解,时间复杂度为O(n2);也可以先排序再加以判断,时间复杂度为O(nlogn);下面的解法时间复杂度为O(n),值得看一下。

算法思路:在原序列中去除两个不同的元素后,原序列中的多数元素在新序列中还是多数元素。

//多数元素(一个数组中一个元素出现的次数超过数组长度的一半) 

#include <stdio.h>
#define M 10

int search(int *num,int address);
int judge(int *num);

int main(void)
{
	int num[M]={1,2,1,1,5,2,1,1,3,1};
	int tmp = judge(num);
	if(tmp>-9999999) printf("%d",tmp);
	else printf("None");
	return 0;
} 
int judge(int *num)
{
	//对返回的值进行判断,是否数量大于n/2。因为如果num数组中不存在多数元素,search也会返回一个值 
	int tmp = search(num,0),i=0,count=0;
	for(i=0;i<M;i++)
	{
		if(tmp==num[i]) count++;
	}
	if(count>=M/2) return tmp;
	else return -9999999;
}
int search(int *num,int address)
{
	int j = address,tmp = num[address],count=1;
	//递归函数从第一个元素开始,成对去除不同的元素 
	while(j<M-1&&count>0) 
	{
		++j;
		if(tmp==num[j]) count++;
		else count--;
	}
	if(j==M-1) return tmp;
	else return search(num,j+1);
}

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

我要出家当道士

打赏是不可能,这辈子都不可能

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值