概述
数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字。例如输入一个长度为9的数组{1,2,3,2,2,2,5,4,2}。由于数字2在数组中出现了5次,超过数组长度的一半,因此输出2。如果不存在则输出0。
思路:
hashmap保存元素以及出现的次数;
遍历map找到出现次数超过一半的元素;
时间o(n) 空间 o(n)
public int MoreThanHalfNum_Solution(int [] array) {
int res=0;
HashMap<Integer,Integer> map=new HashMap<>();
for(int num:array){
map.put(num,map.getOrDefault(num,0)+1);
}
for(int key:map.keySet()){
if(map.get(key)>(array.length/2)){
res=key;
}
}
return res;
}
思路:
时间o(n) 空间o(1)
res=nums[0] count=1; 遍历数组元素;
如果后一个元素和前一个元素相等;count+1; 不相等 count-1;
最后一个让count>0 的元素就有可能是我们要查找的元素;
最后还需要遍历数组判断该元素出现的次数是否大于数组元素的一半;是,返回该元素;否;返回0
难点:使用+1;-1的操作对两种元素进行计数统计,一次遍历数组的思想
public int MoreThanHalfNum_Solution(int [] array) {
if(array==null || array.length==0){
return 0;
}
int result=array[0];
int count=1;
for(int i=1;i<array.length;i++){
if(count==0){
result=array[i];
count++;
}else{
if(array[i]==result){
count++;
}else{
count--;
}
}
}
int time=0;
for(int i=0;i<array.length;i++){
if(array[i]==result){
time++;
}
}
if(2*time<= array.length){
result=0;
}
return result;
}
最后
以上就是体贴彩虹为你收集整理的5:数组:数组中有一个数字出现的次数超过数组长度的一半-Java的全部内容,希望文章能够帮你解决5:数组:数组中有一个数字出现的次数超过数组长度的一半-Java所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复