題目描述
在一個長度為 n 的數(shù)組 nums 里的所有數(shù)字都在 0~n-1 的范圍內。數(shù)組中某些數(shù)字是重復的,但不知道有幾個數(shù)字重復了,也不知道每個數(shù)字重復了幾次。請找出數(shù)組中任意一個重復的數(shù)字。
示例 :
輸入:
[2, 3, 1, 0, 2, 5, 3]
輸出:2 或 3
思路分析
首先想到的是暴力法—兩個for循環(huán)實現(xiàn),缺點很明顯:用時過多。再進一步可以先排序數(shù)組然后一次for循環(huán),容易找出所有的重復元素以及重復的次數(shù),用時依舊較長。
我們考慮如果每個數(shù)字都置出現(xiàn)一次,那么此時是最完美的,每一個下標i對應元素numbers[i],也就是說我們對于數(shù)組中的每個元素numbers[i]都把它放在自己應該在的位置上numbers[numbers[i]]上, 如果我們發(fā)現(xiàn)有兩個元素想往同一個位置上放的時候,說明此元素必然重復
即如下的過程:
-
如果numbers[i] == i, 那么我們認為number[i]這個元素是在自己的位置上的
-
否則的話,numbers[i]這個元素就應在numbers[numbers[i]]這個位置上, 于是交換numbers[i]和numbers[numbers[i]]。
-
重復操作1, 直到number[i]== i, 則繼續(xù)操作下一個位置的元素, 或者numbers[i] == numbers[numbers[i],元素重復。
代碼實現(xiàn)
//#include <stdlib.h> //C語言
#include<iostream>
using namespace std;
//2020.05.22
int findRepeatNumber(int* nums, int numsSize) {
//此題無須增加對數(shù)組為空、元素個數(shù)為0、元素越界情況的判斷
for (int i = 0; i < numsSize; i++) {
//如果元素位置不對,則交換
while (nums[i] != i) {
//交換前檢查是否相等
if (nums[i] == nums[nums[i]])
return nums[i];
int temp = nums[i];
nums[i] = nums[temp];
nums[temp] = temp;
}
}
return -1;
}
int main()
{
int a[] ={2, 3, 1, 0, 2, 5, 3};
findRepeatNumber(a,7);
printf("%d",findRepeatNumber(a,7));
return 0;
}
最新原創(chuàng)推薦
免責聲明:本文內容由21ic獲得授權后發(fā)布,版權歸原作者所有,本平臺僅提供信息存儲服務。文章僅代表作者個人觀點,不代表本平臺立場,如有問題,請聯(lián)系我們,謝謝!