• 剑指offer面试题29 数组中出现次数超过一半的数字


    考察点

    数组
    
    • 1

    知识点

    题目

    分析
    本题目要求数组中出现次数超过一半的数字,其实是需要有一点数学思维,遍历数组,假设第一个元素就是超过一半的元素,并且记录元素出现的次数times,当遇到跟他一样的元素的时候times++,不一样的时候times–,直到times=0的时候可以暂时说明这个元素出现的次数肯定不是超过一半的,超过一半的元素最终times一定是大于0的那个

    public class TwentyNine {
    	public static void main(String[] args) {
    		int[] arr = {1,2,3,2,2,2,5,4,2};
    		try {
    			System.out.println(findMHalf(arr));
    		} catch (Error e) {
    			System.out.println(e);
    		}
    		int[] brr = {1,2,3,2,2,5,5,4};
    		try {
    			System.out.println(findMHalf(brr));
    		} catch (Error e) {
    			System.out.println(e);
    		}
    	}
    	public static int findMHalf(int[] arr) {
    		if (arr == null||arr.length <= 0) {
    			throw new Error("input error");
    		}
    		int result = arr[0];
    		int times = 1;
    		for (int i = 1;i<arr.length;i++) {
    			if (result == arr[i]) {
    				times++;
    			} else if(times > 0) {
    				times--;
    			} else {
    				result = arr[i];
    				times = 1;
    			}
    		}
    		int count = 0;
    		for (int i = 0;i<arr.length;i++) {
    			if(result == arr[i]) {
    				count++;
    			}
    		}
    		if (count > arr.length/2) {
    			return result;
    		}
    		throw new Error("input error");
    	}
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
  • 相关阅读:
    【MATLAB】基本数学操作
    RSA主要攻击方法
    Java I/O流相关操作
    localhost与127.0.0.1和本机ip的区别
    labml-nn:带注释的 pyTorch 论文实现
    python文件操作(一)
    mybatis第二天
    acedGetString 函数
    PO change log 表 cdhdr username 更改 增强
    20道真题训练|学会二叉树的前世今生(三)
  • 原文地址:https://blog.csdn.net/wellwang1993/article/details/136589637