欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

如何解決C++中查找與排序的面試題-創(chuàng)新互聯(lián)

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

目前成都創(chuàng)新互聯(lián)已為近千家的企業(yè)提供了網(wǎng)站建設(shè)、域名、網(wǎng)頁(yè)空間、綿陽(yáng)服務(wù)器托管、企業(yè)網(wǎng)站設(shè)計(jì)、潢川網(wǎng)站維護(hù)等服務(wù),公司將堅(jiān)持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長(zhǎng),共同發(fā)展。

題目:

   旋轉(zhuǎn)數(shù)組的最小數(shù)字

   把一個(gè)數(shù)組最開(kāi)始的若干個(gè)元素搬到數(shù)組的末尾,輸入一個(gè)遞增排序的數(shù)組的一個(gè)旋轉(zhuǎn),輸出旋轉(zhuǎn)數(shù)字的最小元素。

   例:{2,3,4,0,1}是{0,1,2,3,4}的旋轉(zhuǎn),該數(shù)組最小值為0

程序1.0

   失敗的程序,從頭遍歷一遍,時(shí)間復(fù)雜度O(N),這個(gè)思路沒(méi)有利用輸入旋轉(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個(gè)元素則直接返回
	
	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];

}
//在第一次檢測(cè)時(shí)發(fā)現(xiàn)怎么跑都是返回的第一個(gè)元素的值,后來(lái)檢測(cè)時(shí)發(fā)現(xiàn)是在while循環(huán)塊中在定義mid時(shí)在前面不小心加了個(gè)int,這使得這個(gè)mid為這個(gè)塊的局部變量,出了這個(gè)循環(huán)后就被丟棄

程序3.0

   在2.0中有考慮不完善的地方,若數(shù)組為{1,0,1,1,1}或者為{1,1,1,0,1},其左右和中間都是1,無(wú)法移動(dòng)兩個(gè)指針來(lái)縮小查找范圍,因而不得不采取順序查找的方法

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];

}

測(cè)試

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)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。

創(chuàng)新互聯(lián)www.cdcxhl.cn,專業(yè)提供香港、美國(guó)云服務(wù)器,動(dòng)態(tài)BGP最優(yōu)骨干路由自動(dòng)選擇,持續(xù)穩(wěn)定高效的網(wǎng)絡(luò)助力業(yè)務(wù)部署。公司持有工信部辦法的idc、isp許可證, 機(jī)房獨(dú)有T級(jí)流量清洗系統(tǒng)配攻擊溯源,準(zhǔn)確進(jìn)行流量調(diào)度,確保服務(wù)器高可用性。佳節(jié)活動(dòng)現(xiàn)已開(kāi)啟,新人活動(dòng)云服務(wù)器買(mǎi)多久送多久。

網(wǎng)站題目:如何解決C++中查找與排序的面試題-創(chuàng)新互聯(lián)
文章起源:http://aaarwkj.com/article36/dddjsg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供手機(jī)網(wǎng)站建設(shè)、標(biāo)簽優(yōu)化、搜索引擎優(yōu)化、網(wǎng)站排名云服務(wù)器、ChatGPT

廣告

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

網(wǎng)站建設(shè)網(wǎng)站維護(hù)公司
秋霞三级在线免费观看| 麻豆国产原创av色哟哟| 亚洲中文字幕乱码一二三| 日本一欧美一欧美一亚洲| 亚洲欧美综合伊人看片综合| 日本韩国国语对白一区二区三区 | 91超碰在线观看中文| 国产伊人久久综合网| 亚洲av午夜福利麻豆av| 亚洲av在线观看午夜| 亚洲精品成人一区二区| 亚洲国产精品中文字幕一区久久 | 国产精品老熟女一区二区| 日韩人妻一区二区三区蜜桃视频密| 日韩精品免费一区二区三区| 九九re久久这里有精品| 欧美亚洲另类在线日韩国产| 亚洲av香蕉一区二区| 国产强烈高潮粗暴对白| 亚洲精品一区二区毛豆| 日韩二区三区在线观看| 欧美视频在线观看香蕉| 黄色国产欧美国产亚洲| 欧美一区二区国产精品日韩| jk黑丝白丝国产精品| 欧美日韩久久免费观看| 九九re久久这里有精品| 亚洲一区二区三区精品乱码| 91熟女成人精品一区二区| 亚洲免费一级黄色录像片| 91免费在线观看高清| 久久精品国产亚洲av麻豆她| 一区二区五区日韩国产| 激情五月婷婷久久激情| 日韩成人大片在线播放| 未满十八禁在线观看免费| 亚洲国产欧美日韩在线| 人妻熟妇一区二区三区成人| 亚洲中文字幕少妇视频| 国产原创剧情免费观看av| 九九视频免费观看91|