zoukankan      html  css  js  c++  java
  • 软工课堂练习-找水王

    题目描述

    设计思想

    若要统计所有数字的出现次数,则水王的出现次数减去其余数字的次数所得的结果大于0,因此我们可以将统计所有数字出现次数转变为统计每个数字出现次数与其余数字出现次数之差。具体的实现方式是从头开始将第一数设置为候选数,出现次数为1,将其与相邻的下一个数作比较,若相等则次数加一否则减一,若此时该候选数的次数被减为0则将下一个数作为候选数重复此步骤,最终剩下的即为水王。其中有一种极端情况是水王的出现次数占一半且将其余数字依次隔开,此时按照上述算法则没有结果,此时水王出现在最后一位,只需要额外统计最后一位的出现次数将其与全长的一半比较即可,若刚好为一半则确定为水王。

    代码实现

    package findWaterKing;
    
    public class findWaterKing {
    	public static void main(String[] args) {
    		find(new int[]{1,6,2,6,3,6,4,6,5,6});
    	}
    
    	private static void find(int[] is) {
    		int candidate=is[0];
    		int times=0;
    		int count=0;
    		for (int i = 0; i < is.length; i++) {
    			if (is[i] == is[is.length-1]) {
    				count++;
    			}
    			if (times == 0) {
    				candidate = is[i];
    				times = 1;
    				continue;
    			}
    			if (is[i] == candidate) {
    				times++;
    			} else {
    				times--;
    			}
    		}
    		if (count == is.length/2) {
    			System.out.println(is[is.length-1]);
    		} else {
    			System.out.println(candidate);
    		}
    	}
    }
    
    

    实现截图

  • 相关阅读:
    AppDelegate减负之常用三方封装
    AppDelegate减负之常用三方封装
    基于AFN封装的带缓存的网络请求
    iOS-创建自己的日志系统
    UIImage 图片处理:截图,缩放,设定大小,存储
    /bin/sh^M: bad interpreter:解决办法
    mac上获取手机的uuid
    iOS PureLayout使用
    iOS集成友盟推送
    完全理解Python的 '==' 和 'is'
  • 原文地址:https://www.cnblogs.com/52bb/p/12988199.html
Copyright © 2011-2022 走看看