找出一个数组中出现次数最大的数

简介: 描叙:一大堆数据里面,数字与数字之间用空格隔开,找出出现次数最多的一个数字的算法   #include void FindMostTimesDigit(int *Src , int SrcLen) { int element , has = SrcLen; int MaxNu...

描叙:一大堆数据里面,数字与数字之间用空格隔开,找出出现次数最多的一个数字的算法

 

#include<stdio.h>

void FindMostTimesDigit(int *Src , int SrcLen)
{
	int element , has = SrcLen;
	int MaxNum , TempCount = 0 , MaxCount = 0;
	int i , j , *result = new int[];

	while(0 != has)
	{
		TempCount = 0;
		element = Src[has - 1];
		for(j = has - 1 ; j >= 0 ; --j)
		{
		     // 如果找到,则计数加1,然后将数据和末尾交换         
             // 这也是为何要从末尾开始循环的理由      
			if(element == Src[j])
			{
				TempCount++;
				// 把后面的数据移动到前面来
				Src[j] = Src[has - 1];
				has--;
			}
		}

		if(TempCount > MaxCount)
		{
			MaxCount = TempCount;
			MaxNum = 0;
			result[MaxNum] = element;
		}
		else if(TempCount == MaxCount)
		{
			result[++MaxNum] = element;
		}
	}

	printf("出现最多的次数:%d\n" , MaxCount);

	for(i = 0 ; i <= MaxNum ; ++i)
	{
		printf("%d " , result[i]);
	}
	printf("\n");		
}

int main()   
{   
    int list[]={1,2,3,4,3,3,2,2,1,1,4,4,4,1,2};         
    int length =sizeof(list) / sizeof(int);              
    FindMostTimesDigit(list, length);   
        
    return 0;     
}

 

 

C++解法如下:

 1 #include<iostream>
 2 #include<map>
 3 #include<utility>
 4 using namespace std;
 5 
 6 int main()
 7 {
 8     map<int , int> word_count;
 9     int number;
10     while(cin>>number)
11     {
12         pair<map<int , int>::iterator , bool> ret = word_count.insert(make_pair(number , 1));
13         if(!ret.second)
14             ++ret.first->second;
15     }
16 
17     for(map<int , int>::iterator iter = word_count.begin() ; iter != word_count.end() ; ++iter)
18         cout<<(*iter).first<<"\t\t"
19             <<(*iter).second<<endl;
20 
21     return 0;
22 }

 

更简洁的方法如下:

 1 #include<iostream>
 2 #include<map>
 3 #include<utility>
 4 using namespace std;
 5 
 6 int main()
 7 {
 8     map<int , int> word_count;
 9     int number;
10 
11     while(cin>>number)
12         ++word_count[number];
13 
14     for(map<int , int>::iterator iter = word_count.begin() ; iter != word_count.end() ; ++iter)
15         cout<<(*iter).first<<"\t\t"
16             <<(*iter).second<<endl;
17 
18     return 0;
19 }

 

网上看到一哥们也写了类似的东西:http://blog.csdn.net/tianmohust/article/details/7514618

img_e00999465d1c2c1b02df587a3ec9c13d.jpg
微信公众号: 猿人谷
如果您认为阅读这篇博客让您有些收获,不妨点击一下右下角的【推荐】
如果您希望与我交流互动,欢迎关注微信公众号
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接。

相关文章
|
4月前
|
人工智能 监控 安全
Go通道机制与应用详解
本文全面解析了Go语言中的通道(Channel),从基础概念到高级应用,涵盖创建、操作、垃圾回收及实际场景使用。通道作为Go并发模型的核心,支持协程间安全高效的数据通信与同步。文章介绍了无缓冲和有缓冲通道的特性,以及发送、接收、关闭等操作,并探讨了`select`语句、超时处理、遍历通道等高级用法。此外,还深入分析了通道的垃圾回收机制,包括引用计数、生命周期管理和循环引用问题。最后通过数据流处理、任务调度和状态监控等实例,展示了通道在实际开发中的广泛应用。理解通道不仅有助于构建高并发系统,还能优化资源管理,提升程序性能。
156 31
|
9月前
|
机器学习/深度学习 人工智能 PyTorch
使用PyTorch实现GPT-2直接偏好优化训练:DPO方法改进及其与监督微调的效果对比
本文将系统阐述DPO的工作原理、实现机制,以及其与传统RLHF和SFT方法的本质区别。
615 22
使用PyTorch实现GPT-2直接偏好优化训练:DPO方法改进及其与监督微调的效果对比
|
10月前
|
Web App开发 前端开发 JavaScript
揭秘!前端大牛们如何巧妙利用CSS3,打造炫酷视觉效果!
【10月更文挑战第31天】前端开发面临复杂布局的挑战,本文介绍了几种提升开发效率和代码质量的工具和技术。基础的HTML和CSS可以应对大部分布局需求,而Firefox开发者工具、VS Code、Vue、React等则能应对更复杂的布局,帮助开发者构建高性能、用户友好的网页应用。
248 4
|
10月前
|
前端开发 开发者
CSS中的长度单位详解
通过合理选择和组合使用不同的长度单位,开发者可以实现高效、灵活和响应式的Web布局设计。以上详解希望能帮助你更好地理解和应用CSS中的长度单位,提高页面的表现力和可维护性。
282 3
|
11月前
|
前端开发 数据可视化 网络安全
哪个CMS更符合企业搭建网站的需求?
在现代数字互联网时代,企业拥有一个易用、高效和稳定的网站管理系统尤其重要。在众多CMS网站管理系统中,如何选择一个更适合自己搭建企业官网的选择?今天给大家推荐一款网上比较常用的CMS系统:PageAdmin CMS,下面内容给您分析,为什么PageAdmin CMS是符合搭建搭建官网的需求?
156 0
Exception in thread "main" java.lang.IllegalArgumentException: U+6570 ('.notdef') is not available in the font Helvetica-Bold, encoding: WinAnsiEncoding 问题解决
【5月更文挑战第26天】Exception in thread "main" java.lang.IllegalArgumentException: U+6570 ('.notdef') is not available in the font Helvetica-Bold, encoding: WinAnsiEncoding 问题解决
886 2
|
C语言
C语言生成随机数
C语言生成随机数
|
存储 Ubuntu Unix
嵌入式linux/鸿蒙开发板(IMX6ULL)开发(一) 嵌入式Linux开发基本概念以及开发流程介绍
嵌入式linux/鸿蒙开发板(IMX6ULL)开发(一) 嵌入式Linux开发基本概念以及开发流程介绍
1160 0
嵌入式linux/鸿蒙开发板(IMX6ULL)开发(一) 嵌入式Linux开发基本概念以及开发流程介绍
|
机器学习/深度学习 传感器 算法
【图像重建】基于ART算法和SIRT算法实现超声CT反演附MATLAB代码
【图像重建】基于ART算法和SIRT算法实现超声CT反演附MATLAB代码
|
存储 XML 监控
Android 应用安全机制实现方案探究
APP开发完成后,需要进行加固、签名等安全操作,若应用不做任何安全防护,极易被病毒植入、广告替换、支付渠道篡改、钓鱼、信息劫持等,严重侵害开发者的利益。App 加固后,可以对应用进行安全防护,防止应用分发后,被反编译、调试、盗版、破解、二次打包等威胁,维护开发者的利益。除了对APP进行加固操作,还需要进行签名。APP通过对 Apk 进行签名,开发者可以证明对 Apk 的所有权和控制权,可用于安装和更新其应用。而在 Android 设备上安装 Apk ,如果是一个没有被签名的 Apk,则会被拒绝安装。
570 1
Android 应用安全机制实现方案探究

热门文章

最新文章