原文:【c语言】数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字

题目:数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字。 比如输入一个长度为 的数组 , 。 。 , 。 。 , 。 , 因为数组中数字 出现了 次,超过数组的长度的一半,因此输出 一种办法是先把数组排序。那么超过一半的元素一定是数组最中间的元素。 另外一种办法比較抽象。设一个变量保存当前值。设一个次数,当前值与下一个值进行比較。假设相等,次数加一,假设不相等。次数减一。假设次数减到 ...

2017-06-29 17:00 0 2338 推荐指数:

查看详情

数组中有一个数字出现次数超过数组长度一半找出个数

数组中有一个数字出现次数超过数组长度一半找出个数 这个算法的时间复杂度是O(n),另外用了两个辅助变量。 k用于临时存储数组中的数据,j用于存储某个数出现次数。 开始时k存储数组中的第一个数,j为0,如果数组出现的数于k相等,则j加1,否则就减1,如果j为0,就把当前数组中的数赋给k ...

Wed Sep 16 23:16:00 CST 2015 0 2529
一个整型数组中有一个元素的出现次数超过数组长度一半,试设计一个 在时间上尽可能高效的算法,找出这个元素。

题目:在一个整型数组中有一个元素的出现次数超过数组长度一半,试设计一个 在时间上尽可能高效的算法,找出这个元素。要求:(1)给出算法的基本设计思想。(2)根据设计思想,采用CC++或Java语言描述算法,关键之处给出注释。(3)说明你所设计算法的时间复杂度和空间复杂度 ...

Wed Oct 29 00:19:00 CST 2014 0 2354
数组出现次数超过一半数字

数组中有一个数字出现次数超过数组长度一半找出个数字。 例如输入数组:{1,3,3,2,3,2,3,3,2}。由于2在数组出现了5次,超过数组长度一半,因此要输出2。 有两种解法: 第一种方法是基于快速排序算法的原理,边排序边判断是否符合输出条件。这种方法的代码我因为没有保存 ...

Sun May 11 00:26:00 CST 2014 0 5492
数组出现次数超过一半数字

数组出现次数超过一半数字 题目描述 数组中有一个数字出现次数超过数组长度一半找出个数字。例如输入一个长度为9的数组{1,2,3,2,2,2,5,4,2}。由于数字2在数组出现了5次,超过数组长度一半,因此输出2。如果不存在则输出0 版本一: map映射, 哈希 ...

Thu Mar 07 18:13:00 CST 2019 0 937
数组出现次数超过一半数字

题目描述 数组中有一个数字出现次数超过数组长度一半找出个数字。例如输入一个长度为9的数组{1,2,3,2,2,2,5,4,2}。由于数字2在数组出现了5次,超过数组长度一半,因此输出2。如果不存在则输出0。 方法一 ---- 基于随机快排 如果数组中存在一个数字出现 ...

Mon Mar 25 22:16:00 CST 2019 0 945
一个简单的算法---实现找出数组一个数字出现次数最多的数字

程序员=编程语言基础+数据结构+算法 这几天继续回归java基础,以及学习数据结构的知识,这里实现一个简单的算法----找出数组一个数字出现次数最多的数字的算法 打印结果如下: 出现次数最多的数字为:2 该数字一共出现6次 ...

Wed Nov 21 05:10:00 CST 2012 0 6959
数组出现次数超过一半数字 -java

##数组出现次数超过一半数字 -java 方法一: 数组排序,然后中间值肯定是要查找的值。 排序最小的时间复杂度(快速排序)O(NlogN),加上遍历。 方法二: 使用散列表的方式,也就是统计每个数组出现次数,输出出现次数大于数组长度数字。 方法三: 出现次数超过数组长度一半,表明 ...

Sat Feb 20 23:54:00 CST 2016 1 6046
 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM