亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

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

發布時間:2022-01-15 14:25:40 來源:億速云 閱讀:140 作者:小新 欄目:編程語言

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

題目:

    旋轉數組的最小數字

    把一個數組最開始的若干個元素搬到數組的末尾,輸入一個遞增排序的數組的一個旋轉,輸出旋轉數字的最小元素。

    例:{2,3,4,0,1}是{0,1,2,3,4}的旋轉,該數組最小值為0

程序1.0

    失敗的程序,從頭遍歷一遍,時間復雜度O(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,這樣若旋轉了0個元素則直接返回
	
	while (array[left] >= array[right])//數組為旋轉后數組
	{
		
		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];

}
//在第一次檢測時發現怎么跑都是返回的第一個元素的值,后來檢測時發現是在while循環塊中在定義mid時在前面不小心加了個int,這使得這個mid為這個塊的局部變量,出了這個循環后就被丟棄

程序3.0

    在2.0中有考慮不完善的地方,若數組為{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);
}

關于“如何解決C++中查找與排序的面試題”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

c++
AI

枣强县| 枝江市| 昭苏县| 吉安县| 延津县| 乐都县| 江北区| 招远市| 庆元县| 南宫市| 同仁县| 崇义县| 绥中县| 大埔县| 藁城市| 方城县| 绥德县| 齐齐哈尔市| 湟中县| 顺平县| 吉水县| 平阴县| 炉霍县| 尖扎县| 乌兰县| 汶川县| 兴义市| 米脂县| 万山特区| 天全县| 清水县| 中卫市| 留坝县| 安多县| 微山县| 梅河口市| 陈巴尔虎旗| 攀枝花市| 松溪县| 周至县| 比如县|