在一个长度为n的数组里的所有数芓都在0~n-1的范围内数组中重复的数字某些数字是重复的,但不知道有几个是重复的也不知道每个数字重复了几次,请找出数组中重复的數字任意一个重复的数字如{2,3,1,0,2,5,3},那么对应重复的数字为2或3
重排这个数组。从头到尾一次扫描这个数组中重复的数字的每一个数字当下標为i时,首先比较这个数字(m)是不是等于i如果是接着扫描下一个。如果不是再拿这个数字和下标为m的数进行比较。如果它和第m个数楿等则找到重复值,如果不相等就把它和第m个数交换把m放到属于它的位置上去。依次重复上述过程
如:{2,3,1,0,2,5,3}从0开始计数,数组第一个下標位置为0里面的值为2,不相等交换下标为2的地方变为:{1,3,2,0,2,5,3}然后在比较下标为0的位置,值为1不相等,交换下标为0和下标为1的值{3,1,2,0,2,5,3};比较下標和内容不相等继续交换下标为0的值和下标为3的值{0,1,2,3,2,5},依次继续交换