當(dāng)前位置:首頁 > 公眾號(hào)精選 > C語言與CPP編程
[導(dǎo)讀]題目描述 在一個(gè)長(zhǎng)度為 n 的數(shù)組 nums 里的所有數(shù)字都在 0~n-1 的范圍內(nèi)。數(shù)組中某些數(shù)字是重復(fù)的,但不知道有幾個(gè)數(shù)字重復(fù)了,也不知道每個(gè)數(shù)字重復(fù)了幾次。請(qǐng)找出數(shù)組中任意一個(gè)重復(fù)的數(shù)字。 示例 : 輸入: [2, 3, 1, 0, 2, 5, 3] 輸出:2 或 3 思路分析


題目描述

在一個(gè)長(zhǎng)度為 n 的數(shù)組 nums 里的所有數(shù)字都在 0~n-1 的范圍內(nèi)。數(shù)組中某些數(shù)字是重復(fù)的,但不知道有幾個(gè)數(shù)字重復(fù)了,也不知道每個(gè)數(shù)字重復(fù)了幾次。請(qǐng)找出數(shù)組中任意一個(gè)重復(fù)的數(shù)字。

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

思路分析

首先想到的是暴力法—兩個(gè)for循環(huán)實(shí)現(xiàn),缺點(diǎn)很明顯:用時(shí)過多。再進(jìn)一步可以先排序數(shù)組然后一次for循環(huán),容易找出所有的重復(fù)元素以及重復(fù)的次數(shù),用時(shí)依舊較長(zhǎng)。

我們考慮如果每個(gè)數(shù)字都置出現(xiàn)一次,那么此時(shí)是最完美的,每一個(gè)下標(biāo)i對(duì)應(yīng)元素numbers[i],也就是說我們對(duì)于數(shù)組中的每個(gè)元素numbers[i]都把它放在自己應(yīng)該在的位置上numbers[numbers[i]]上, 如果我們發(fā)現(xiàn)有兩個(gè)元素想往同一個(gè)位置上放的時(shí)候,說明此元素必然重復(fù)

即如下的過程:

  • 如果numbers[i] == i, 那么我們認(rèn)為number[i]這個(gè)元素是在自己的位置上的

  • 否則的話,numbers[i]這個(gè)元素就應(yīng)在numbers[numbers[i]]這個(gè)位置上, 于是交換numbers[i]和numbers[numbers[i]]。

  • 重復(fù)操作1, 直到number[i]== i, 則繼續(xù)操作下一個(gè)位置的元素, 或者numbers[i] == numbers[numbers[i],元素重復(fù)。

代碼實(shí)現(xiàn)

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

//2020.05.22
int findRepeatNumber(int* nums, int numsSize) {
//此題無須增加對(duì)數(shù)組為空、元素個(gè)數(shù)為0、元素越界情況的判斷
for (int i = 0; i < numsSize; i++) {
//如果元素位置不對(duì),則交換
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;
}
運(yùn)行結(jié)果


最新原創(chuàng)推薦

十大經(jīng)典排序算法(動(dòng)態(tài)演示+代碼)

C語言與C++面試知識(shí)總結(jié)
數(shù)據(jù)結(jié)構(gòu)之堆棧

一文輕松理解內(nèi)存對(duì)齊

一文讀懂C語言與C++動(dòng)態(tài)內(nèi)存

面試中常見的C語言C++區(qū)別的問題

數(shù)據(jù)結(jié)構(gòu)之線性表

免責(zé)聲明:本文內(nèi)容由21ic獲得授權(quán)后發(fā)布,版權(quán)歸原作者所有,本平臺(tái)僅提供信息存儲(chǔ)服務(wù)。文章僅代表作者個(gè)人觀點(diǎn),不代表本平臺(tái)立場(chǎng),如有問題,請(qǐng)聯(lián)系我們,謝謝!

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國(guó)汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場(chǎng)的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營(yíng)業(yè)績(jī)穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤(rùn)率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長(zhǎng) 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競(jìng)爭(zhēng)力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競(jìng)爭(zhēng)優(yōu)勢(shì)...

關(guān)鍵字: 通信 BSP 電信運(yùn)營(yíng)商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國(guó)電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場(chǎng) NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長(zhǎng)三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡(jiǎn)稱"軟通動(dòng)力")與長(zhǎng)三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉