C# 二分法查找和排序
2024-08-14 08:44:06 219人阅读
using System; using System.Collections.Generic; using System.Text; namespace AAA { public class Dichotomy { public static void DichotomySort(int[] array) { for (int i = 0; i < array.Length; i++) { int start = 0; int end = i - 1; int middle = 0; int temp = array[i]; while (start <= end) { middle = (start + end) / 2; if (array[middle] > temp)//要排序元素在已经排过序的数组左边 { end = middle - 1; } else { start = middle + 1; } } for (int j = i - 1; j > end; j--)//找到了要插入的位置,然后将这个位置以后的所有元素向后移动 { array[j + 1] = array[j]; } array[end + 1] = temp; } } public static long DichotomySearch(long[] array, long key, long high, long low) { long middle = 0; if (high < low) { return -1; } middle = (low + high) / 2; if (array[middle] == key) { return middle; } else if (array[middle] > key) { return DichotomySearch(array, key, middle - 1, low); } else { return DichotomySearch(array, key,high, middle + 1); } } } }
|
C# 二分法查找和排序
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉:
投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。