水王问题的实质就是如何快速在一串连续的数字里找到出现次数超过一半的数字。
重点是最快,把这串数字放到一个数组里面,两个相邻的数字去做比较,如果相等,在向后比较,如果不等把这两个数字都置为0,标明这两个数字已经相互抵消。水王的数字最多,最后数组里面只有水王的数字。
1 package Main; 2 3 public class Main{ 4 public static void main(String[] args) 5 { 6 //把i帖子序号d列表放到一个数组里面 7 int[] idNum = {1,2,3,2,2,4,2,5,6,2,7,2,8,2,5,2,2}; 8 //指向前一个数和后一个数的指针 9 int up = 0; 10 int next = 1; 11 //通过while循环来实现两两相消法 12 while((up < idNum.length-1)&&(next < idNum.length)) 13 { 14 //如果前一个数字和后一个数字相等则指针顺次向后移动一位 15 if(idNum[up] == idNum[next]) 16 { 17 up = up + 1; 18 next = next + 1; 19 } 20 //如果前一个数和后一个数不相等这两个数就相互消去指针顺次移动两位 21 else 22 { 23 idNum[up] = 0; 24 idNum[next] = 0; 25 up = up + 2; 26 next = next + 2; 27 } 28 } 29 30 //两两相消完之后找到第一个不是0的数组元素找到了水王的id 31 next = 0; 32 while(next < idNum.length) 33 { 34 if(idNum[next] != 0) 35 { 36 System.out.println("水王是"+idNum[next]); 37 break; 38 } 39 else 40 { 41 next = next + 1; 42 } 43 } 44 45 } 46 }