基于Java代码实现数字在数组中出现次数超过一半

网友投稿 199 2023-07-21


基于Java代码实现数字在数组中出现次数超过一半

下文通过几种方法给大家介绍java数组数字出现次数,具体内容如下所示:

方法一:

数组排序,然后中间值肯定是要查找的值。 排序最小的时间复杂度(快速排序)O(NlogN),加上遍历。

方法二:

使用散列表的方式,也就是统计每个数组出现的次数,输出出现次数大于数组长度的数字。

方法三:

出现的次数超过数组长度的一半,表明这个数字出现的次数比其他数出现的次数的总和还多。

考虑每次删除两个不同的数,那么在剩下的数中,出现的次数仍然超过总数的一般,不断重复该过程,排除掉其他的数,最终找到那个出现次数超过一半的数字。这个方法的时间复杂度是O(N),空间复杂度是O(1)。

换个思路,这个可以通过计数实现,而不是真正物理删除。在遍历数组的过程中,保存两个值,一个是数组中数字,一个是出现次数。当遍历到下一个数字时,如http://果这个数字跟之前保存的数字相同,则次数加1,如果不同,则次数减1。如果次数为0,则保存下一个数字并把次数设置为1,由于我们要找的数字出现的次数比其他所有数字出现的次数之和还要多,那么要找的数字肯定是最后一次把次数设为1时对应的数字。

public int MoreHalf(int[] nums) {

int result = 0;

int count = 1;

if (nums.length == 0)

return -1;

result = nums[0];

for (int i = 1; i < nums.length; i++) {

if (count == 0) {

result = nums[i];

count = 1;

continue;

}

if (result == nums[i])

count++;

else

count--;

}

return result;

}

方法四:

改进的快排,前面提到,如果对一个数组进行排序,位于中间位置的那个数字肯定是所求的值。对数组排序的时间复杂度是O(nlog(n)),但是对于这道题目,还有更好的算法,能够在时间复杂度O(n)内求出。

借鉴快速排序算法,其中的Partition()方法是一个最重要的方法,该方法返回一个index,能够保证index位置的数是已排序完成的,在index左边的数都比index所在的数小,在index右边的数都比index所在的数大。那么本题就可以利用这样的思路来解。

通过Partition()返回index,如果index==mid,那么就表明找到了数组的中位数;如果indexmid,表明中位数在[start,index-1]之间。知道最后求得index==mid循环结束。

public int Partition(int[] nums,int start,int end){

int pivotkey = nums[start];

int origin = start;

while(start

while(start=pivotkey) end--;

while(start

swap(nums,start,end);

}

swap(nums,start,end);

swap(nums,http://origin,end);

return end;

}

public int[] swap(int[] ints, int x, int y) {

int temp = ints[x];

ints[x] = ints[y];

ints[y] = temp;

return ints;

}

public int MoreThanHalf(int[] nums){

if(nums.length==0)

return -1;

int start = 0;

int end = nums.length-1;

int index = Partition(nums, start, end);

int mid = nums.length/2;

while(index!=mid){

if(index>mid)

//如果调整数组以后获得的index大于middle,则继续调整start到index-1区段的数组

index = Partition(nums, start, index-1);

else{

//否则调整index+1到end区段的数组

index = Partition(nums, index+1, end);

}

}

return numshttp://[index];

}

以上内容给大家介绍了Java代码实现数字在数组中出现次数超过一半的相关内容,希望对大家有所帮助!

while(start=pivotkey) end--;

while(start

swap(nums,start,end);

}

swap(nums,start,end);

swap(nums,http://origin,end);

return end;

}

public int[] swap(int[] ints, int x, int y) {

int temp = ints[x];

ints[x] = ints[y];

ints[y] = temp;

return ints;

}

public int MoreThanHalf(int[] nums){

if(nums.length==0)

return -1;

int start = 0;

int end = nums.length-1;

int index = Partition(nums, start, end);

int mid = nums.length/2;

while(index!=mid){

if(index>mid)

//如果调整数组以后获得的index大于middle,则继续调整start到index-1区段的数组

index = Partition(nums, start, index-1);

else{

//否则调整index+1到end区段的数组

index = Partition(nums, index+1, end);

}

}

return numshttp://[index];

}

以上内容给大家介绍了Java代码实现数字在数组中出现次数超过一半的相关内容,希望对大家有所帮助!

swap(nums,start,end);

}

swap(nums,start,end);

swap(nums,http://origin,end);

return end;

}

public int[] swap(int[] ints, int x, int y) {

int temp = ints[x];

ints[x] = ints[y];

ints[y] = temp;

return ints;

}

public int MoreThanHalf(int[] nums){

if(nums.length==0)

return -1;

int start = 0;

int end = nums.length-1;

int index = Partition(nums, start, end);

int mid = nums.length/2;

while(index!=mid){

if(index>mid)

//如果调整数组以后获得的index大于middle,则继续调整start到index-1区段的数组

index = Partition(nums, start, index-1);

else{

//否则调整index+1到end区段的数组

index = Partition(nums, index+1, end);

}

}

return numshttp://[index];

}

以上内容给大家介绍了Java代码实现数字在数组中出现次数超过一半的相关内容,希望对大家有所帮助!


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:gameboy网页闯关游戏(riddle webgame)
下一篇:java正则表达式学习笔记之命名捕获
相关文章

 发表评论

暂时没有评论,来抢沙发吧~