每日一題:數組中重複的數字(C語言/C++)

題目描述

在一個長度爲 n 的數組 nums 裏的所有數字都在 0~n-1 的範圍內。數組中某些數字是重複的,但不知道有幾個數字重複了,也不知道每個數字重複了幾次。請找出數組中任意一個重複的數字。

示例 :
輸入:
[2, 3, 1, 0, 2, 5, 3]
輸出:2 或 3

思路分析

首先想到的是暴力法—兩個for循環實現,缺點很明顯:用時過多。再進一步可以先排序數組然後一次for循環,容易找出所有的重複元素以及重複的次數,用時依舊較長。

我們考慮如果每個數字都置出現一次,那麼此時是最完美的,每一個下標i對應元素numbers[i],也就是說我們對於數組中的每個元素numbers[i]都把它放在自己應該在的位置上numbers[numbers[i]]上, 如果我們發現有兩個元素想往同一個位置上放的時候,說明此元素必然重複

即如下的過程:

  • 如果numbers[i] == i, 那麼我們認爲number[i]這個元素是在自己的位置上的

  • 否則的話,numbers[i]這個元素就應在numbers[numbers[i]]這個位置上, 於是交換numbers[i]和numbers[numbers[i]]。

  • 重複操作1, 直到number[i]== i, 則繼續操作下一個位置的元素, 或者numbers[i] == numbers[numbers[i],元素重複。

代碼實現

//#include <stdlib.h>   //C語言
#include<iostream>
using namespace std;

//2020.05.22
int findRepeatNumber(int* nums, int numsSize) {
	//此題無須增加對數組爲空、元素個數爲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;
}
運行結果

最新原創推薦

十大經典排序算法(動態演示+代碼)

C語言與C++面試知識總結

數據結構之堆棧

一文輕鬆理解內存對齊

一文讀懂C語言與C++動態內存

面試中常見的C語言與C++區別的問題

數據結構之線性表

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章