排序及查找----[(冒泡,快速)(拉格朗日,二分)]

代码展示:

  1 using System;
  2 using System.Collections.Generic;
  3 using System.Linq;
  4 using System.Text;
  5 using System.Threading.Tasks;
  6 
  7 namespace paixu
  8 {
  9     class Program
 10     {
 11         static void Main()
 12         {
 13             int[] Array = { 1, 45, 8, 65, 478, 5, 56, 1, 0, -87, 878, 4, 64 };
 14 
 15             MaoPao(Array);
 16              Console.WriteLine("-----------冒泡--------------------------");
 17             KuaiSu01(Array);
 18              Console.WriteLine("-----------快速法(一)-------------------");            
 19              KuaiSu02(Array);
 20              Console.WriteLine("-----------快速法(二)-------------------");
 21             
 22 string x = "=========以下两种查找方法必须要有序数组=============";
 23 
 24              LaGeLangRi(Array, 878);
 25              Console.WriteLine("-----------拉格朗日插值查找法-----------");           
 26             Dichotomy(Array,0);
 27              Console.WriteLine("-----------二分法查找法-----------------");
 28             
 29              Console.Read();
 30         }
 31 //---------------------冒泡------------------------------------------------
 32         public static void MaoPao( int [] array) 
 33         {
 34             int temp = 0;
 35             for (int i = 0; i < array.Length-1; i++)
 36             {
 37                 for (int j = 0; j < array.Length - 1 - i; j++)
 38                 {
 39                     if (array[j] > array[j + 1])
 40                     {
 41                         temp = array[j];
 42                         array[j] = array[j + 1];
 43                         array[j + 1] = temp;                    
 44                     }               
 45                 }
 46             }
 47             foreach (int  item in array)
 48             {
 49                 Console.WriteLine(item);
 50             }
 51         }
 52 //---------------------快速(法一)------------------------------------------------------
 53         public static void KuaiSu01( int [] array)
 54         {
 55             List <int> list = array.ToList();
 56             QuickSort(list, 0, array.Length - 1);
 57             foreach (int  i in list)
 58             {
 59                 Console.WriteLine(i.ToString());
 60             }
 61         }
 62         private static int Division(List<int> list, int left, int right)//获取按枢轴值左右分流后枢轴的位置
 63         {
 64             while (left < right)
 65             {
 66                 int num = list[left]; //将首元素作为枢轴
 67                 if (num > list[left + 1])
 68                 {
 69                     list[left] = list[left + 1];
 70                     list[left + 1] = num;
 71                     left++;
 72                 }
 73                 else
 74                 {
 75                     int temp = list[right];
 76                     list[right] = list[left + 1];
 77                     list[left + 1] = temp;
 78                     right--;
 79                 }  
 80             }
 81             return left; //指向的此时枢轴的位置
 82         }
 83         private static void QuickSort(List<int> list, int left, int right)//递归进行操作
 84         {
 85             if (left < right)
 86             {
 87                 int i = Division(list, left, right);
 88                 //对枢轴的左边部分进行排序
 89                 QuickSort(list, i + 1, right);
 90                 //对枢轴的右边部分进行排序
 91                 QuickSort(list, left, i - 1);
 92             }
 93         }
 94 //---------------------快速(法二)-------------------------------------------------------
 95         public static void KuaiSu02(int[] array)
 96         {
 97           
 98             Sort(array, 0, array.Length);
 99             foreach (int i in array)
100             {
101                 Console.WriteLine(i.ToString());
102             }
103         }
104        public static void Sort(int[] nums, int left, int right)//数组,起始下标,数组长度
105         {
106             if (left < right)    //直到排序的左右区间只剩一个值
107             {
108                 int i = left;
109                 int j = right - 1;
110                 int middle = nums[(left + right) / 2];
111                 while (true)
112                 {
113                     while (i < right && nums[i] < middle) { i++; }; 
114                        //在middle左边找到一个比middle小的值
115                     while (j > 0 && nums[j] > middle) { j--; };   
116                           //在middle右边找到一个比middle大的值
117                     if (i == j) {break; } 
118                //当i=j时,middle左边都是比middle小的数,右边都是比middle大的;跳出循环
119                     nums[i] = nums[i] + nums[j];
120                     nums[j] = nums[i] - nums[j];
121                     nums[i] = nums[i] - nums[j];     //两个值交换位置
122                     if (nums[i] == nums[j]) { j--; }
123                        //如果两个值相等,且等于middle,为避免进入死循环,j--
124                 }
125                 Sort(nums, left, i);           //递归 
126                 Sort(nums, i + 1, right);
127             }
128         }
129 
130        //--------拉格朗日插值查找法(相同元素返回第一个元素下标)-----------------         
131        public static int LaGeLangRi(int[] a, int key)
132         {
133              int tou=0;
134             int wei=a.Length-1;
135             int  zhong =0;
136             while(tou<=wei)
137             {
138                 zhong = tou + (wei - tou) * (key - a[tou]) / (a[wei] - a[tou]);
139                 if (key == a[zhong]) { break; }
140                 else if (key > a[zhong]) { tou = zhong + 1; }
141                 else{wei=zhong-1;}
142             }
143             Console.Write(key); Console.WriteLine("---->对应的下标是:" + zhong);           
144             return zhong;
145             
146         }
147 //-------------------二分查找法(相同元素返回第一个元素下标)------------------------
148        public static void Dichotomy(int[] array,int item)
149        {          
150            int x = BinarySearch(array, 0, array.Length - 1, item);
151            Console.Write(item); Console.WriteLine("---->对应的下标是:" + x);                
152        } 
153         public  static int BinarySearch(int[] arr, int low, int high, int key)
154         {
155             int mid = (low + high) / 2;
156             if (low > high){return -1;}               
157             else
158             {
159                 if (arr[mid] == key){ return mid;}                   
160                 else if (arr[mid] > key){return BinarySearch(arr, low, mid - 1, key);}                    
161                 else{return BinarySearch(arr, mid + 1, high, key);}                    
162             }
163             
164         }
165     }
166 }

备注:

排序的话,快速排序效率是较高的.

posted @ 2018-11-01 09:47  薄荷グ微凉べ  阅读(177)  评论(0编辑  收藏  举报