C#中二分法查找的入門(程式碼介紹)

青灯夜游
發布: 2018-10-22 15:32:56
轉載
2652 人瀏覽過

本篇文章透過一個二分法查找的入門案例(程式碼)來跟大家介紹C#中的二分法查找是什麼?有一定的參考價值,有需要的朋友可以參考一下,希望對你們有幫助。

二分法查找:適用於已經排序好的陣列

1、二分法查找(入門案例)

static void Main(string[] args) {
	int[] myNums = {1,13,22,34,56,143,167,211,266,363,466,572,595,645,688,689,702,779,888,899,922};

	Console.WriteLine("我的数组是:");
	for(int i = 0; i < myNums.Length; i++) {
		Console.Write("{0} ", myNums[i]);
	}
	Console.WriteLine();

	//使用二分法从数组查找指定值
	//取得查找值在数组中的索引位置
	int QueryValueIndex = QueryFromTwoParts(688, myNums, 0, myNums.Length - 1);
	Console.WriteLine("--------------------------------------------------------");
	Console.WriteLine("查找值688在数组中的索引位置是:{0}", QueryValueIndex);
	Console.WriteLine("数组myNums索引位置{0}处的值是:{1}", QueryValueIndex, myNums[QueryValueIndex]);

	Console.ReadKey();
}

//该方法返回的是查找值在数组中的索引位置
private static int QueryFromTwoParts(int QueryValue, int[] nums, int leftIndex, int rightIndex) {
	//计算数组中间值的在数组中的索引位置
	int midValueIndex = (leftIndex + rightIndex + 1) / 2;

	//取得数组中间索引位置处的值
	int midValue = nums[midValueIndex];

	//比较中间值与查找值的大小,确定下一步该怎样继续查询
	if(QueryValue == midValue) {
		return midValueIndex;
	} else if(QueryValue < midValue) {
		return QueryFromTwoParts(QueryValue, nums, leftIndex, midValueIndex);
	} else {
		return QueryFromTwoParts(QueryValue, nums, midValueIndex, rightIndex);
	}

}
登入後複製

2、程式碼執行結果:

以上是C#中二分法查找的入門(程式碼介紹)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
c#
來源:cnblogs.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!