自己整理的不算转载
给定一个大小为 n 的数组,找到其中的众数。众数是指在数组中出现次数大于 ⌊ n/2 ⌋ 的元素。
你可以假设数组是非空的,并且给定的数组总是存在众数。
示例 1:

方法一:取数组第一个元素,去循环重复一个就计数为1,没遇到一样的就减一,直到为零换下一个元素去数组碰,剩下的一定是最多的那个
class Solution {
public static void main(String[] args) {
int[] a = {2,2,1,1,1,2,2};
System.out.println(majorityElement(a));
}
public static int majorityElement(int[] nums) {
int a = nums[0];
int count = 1;
for(int num : nums) {
if(num == a) {
count ++;
}else {
count --;
if(count == 0) {
a = num;
count = 1;
}
}
}
return a;
}
}
方法二:先sort排下序,然后取最中间的那个数因为定义的是个数大于数组长度的二分之一
public static void main(String[] args) {
int[] a = {2,2,1,1};
System.out.println(majorityElement(a));
}
public static int majorityElement(int[] nums) {
Arrays.sort(nums);
return nums[nums.length/2];
}

博客介绍了在大小为n的非空数组中查找众数的方法,众数是出现次数大于数组长度一半的元素。给出两种方法,一是通过计数比较,二是先排序再取中间数,还给出了第一种方法的Java代码示例。

1425

被折叠的 条评论
为什么被折叠?



