中文字幕日韩精品一区二区免费_精品一区二区三区国产精品无卡在_国精品无码专区一区二区三区_国产αv三级中文在线

如何解決C++中查找與排序的面試題

這篇文章將為大家詳細(xì)講解有關(guān)如何解決C++中查找與排序的面試題,小編覺得挺實(shí)用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

成都創(chuàng)新互聯(lián)是一家集網(wǎng)站建設(shè),南安企業(yè)網(wǎng)站建設(shè),南安品牌網(wǎng)站建設(shè),網(wǎng)站定制,南安網(wǎng)站建設(shè)報價,網(wǎng)絡(luò)營銷,網(wǎng)絡(luò)優(yōu)化,南安網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強(qiáng)企業(yè)競爭力。可充分滿足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時我們時刻保持專業(yè)、時尚、前沿,時刻以成就客戶成長自我,堅持不斷學(xué)習(xí)、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實(shí)用型網(wǎng)站。

題目:

    旋轉(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

    失敗的程序,從頭遍歷一遍,時間復(fù)雜度O(N),這個思路沒有利用輸入旋轉(zhuǎn)數(shù)組的特性,隨便實(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)容可以對大家有一定的幫助,使各位可以學(xué)到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

分享文章:如何解決C++中查找與排序的面試題
標(biāo)題URL:http://m.rwnh.cn/article6/jijhog.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供營銷型網(wǎng)站建設(shè)、網(wǎng)站維護(hù)、商城網(wǎng)站、用戶體驗(yàn)、動態(tài)網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都定制網(wǎng)站建設(shè)
肇州县| 盖州市| 长岛县| 静宁县| 香格里拉县| 弥渡县| 海宁市| 邯郸县| 涿州市| 北碚区| 西畴县| 江门市| 黔西| 社旗县| 霞浦县| 英德市| 雷波县| 茌平县| 娄烦县| 攀枝花市| 淮安市| 扬中市| 房产| 博客| 婺源县| 太保市| 尤溪县| 阿拉尔市| 托克托县| 綦江县| 谢通门县| 石城县| 任丘市| 江源县| 郎溪县| 青浦区| 随州市| 贵南县| 阆中市| 莎车县| 张家川|