這篇文章將為大家詳細講解有關(guān)如何解決C++中查找與排序的面試題,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
目前成都創(chuàng)新互聯(lián)已為近千家的企業(yè)提供了網(wǎng)站建設(shè)、域名、網(wǎng)頁空間、綿陽服務(wù)器托管、企業(yè)網(wǎng)站設(shè)計、潢川網(wǎng)站維護等服務(wù),公司將堅持客戶導向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長,共同發(fā)展。題目:
旋轉(zhuǎn)數(shù)組的最小數(shù)字
把一個數(shù)組最開始的若干個元素搬到數(shù)組的末尾,輸入一個遞增排序的數(shù)組的一個旋轉(zhuǎn),輸出旋轉(zhuǎn)數(shù)字的最小元素。
例:{2,3,4,0,1}是{0,1,2,3,4}的旋轉(zhuǎn),該數(shù)組最小值為0
程序1.0
失敗的程序,從頭遍歷一遍,時間復雜度O(N),這個思路沒有利用輸入旋轉(zhuǎn)數(shù)組的特性,隨便實現(xiàn)了但是卻是失敗的
int MinNum(int* array, int length) { int cur = array[0]; for (int i = 1; i < length; i++) { if (array[i]<cur) { cur = array[i]; } } return cur; }
程序2.0
方法類似于二分查找
int MinNum(int* array, int length) { assert(array); assert(length>0); int left = 0; int right = length - 1; int mid = left;//初始化為0,這樣若旋轉(zhuǎn)了0個元素則直接返回 while (array[left] >= array[right])//數(shù)組為旋轉(zhuǎn)后數(shù)組 { if (right - left == 1) { mid = right; break; } mid = (left + right) / 2; if (array[mid] >= array[left]) { left = mid; } else if (array[mid] <= array[right]) { right = mid; } } return array[mid]; } //在第一次檢測時發(fā)現(xiàn)怎么跑都是返回的第一個元素的值,后來檢測時發(fā)現(xiàn)是在while循環(huán)塊中在定義mid時在前面不小心加了個int,這使得這個mid為這個塊的局部變量,出了這個循環(huán)后就被丟棄
程序3.0
在2.0中有考慮不完善的地方,若數(shù)組為{1,0,1,1,1}或者為{1,1,1,0,1},其左右和中間都是1,無法移動兩個指針來縮小查找范圍,因而不得不采取順序查找的方法
int MinInOrder(int *array,int left,int right) { int ret = array[left]; for (int i = left + 1; i <= right; i++) { if (ret>array[i]) { ret = array[i]; } } return ret; } int MinNum(int* array, int length) { assert(array); assert(length > 0); int left = 0; int right = length - 1; int mid = left; while (array[left] >= array[right]) { if (right - left == 1) { mid = right; break; } mid = (left + right) / 2; if (array[left] == array[right] && array[left] == array[mid]) { return MinInOrder(array, left, right); } if (array[mid] >= array[left]) { left = mid; } else if (array[mid] <= array[right]) { right = mid; } } return array[mid]; }
測試
void test() { int a[10] = { 8,9,10,11,1,2,3,4,5,6 }; cout<<MinNum(a, 10); } void test1() { int a[5] = { 1, 0, 1, 1, 1 }; cout << MinNum(a, 5); }
關(guān)于“如何解決C++中查找與排序的面試題”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
創(chuàng)新互聯(lián)www.cdcxhl.cn,專業(yè)提供香港、美國云服務(wù)器,動態(tài)BGP最優(yōu)骨干路由自動選擇,持續(xù)穩(wěn)定高效的網(wǎng)絡(luò)助力業(yè)務(wù)部署。公司持有工信部辦法的idc、isp許可證, 機房獨有T級流量清洗系統(tǒng)配攻擊溯源,準確進行流量調(diào)度,確保服務(wù)器高可用性。佳節(jié)活動現(xiàn)已開啟,新人活動云服務(wù)器買多久送多久。
網(wǎng)站題目:如何解決C++中查找與排序的面試題-創(chuàng)新互聯(lián)
文章起源:http://muchs.cn/article36/dddjsg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供手機網(wǎng)站建設(shè)、標簽優(yōu)化、搜索引擎優(yōu)化、網(wǎng)站排名、云服務(wù)器、ChatGPT
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容