亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

C#快速排序算法

2019-11-17 02:50:18
字體:
來源:轉載
供稿:網友

C#快速排序算法

  今天重溫了下排序算法,包括冒泡排序法和直接排序法,這些都比較簡單,只是快速排序法比較難,于是重點研究了下。

  先說一說原理:快速排序法是采用遞歸的方式對待排序的數列進行若干次的操作,每次操作使得被操作的數列部分以某個元素為分界值分成兩部分,一部分小于該分界值,另一部分大于該分界值.該分界值一般被稱為"樞軸". 一般先以左邊第一個數作為分界值,將數列按該分界值分成左右兩部分,左邊部分小于該分界值,右邊部分大于該分界值,然后再對左右兩部分做重復的操作,直到最后完成排序。

以數列 14,11,25,37,9,28 為例,詳細描述執行一趟快速排序的算法:

1,選擇待排序數列的樞軸,一般以數列的首元素作為樞軸.此數列中,我們選擇首元素14作為樞軸,nPivot = 14.

2,設定兩個指針 i 和 j ,分別指向數列的首元素和尾元素. i 指向首元素14, j 指向尾元素28.示意圖如下:

3,向前移動尾指針 j ,使其指向從數列尾部算起首個小于樞軸(即14)的元素,并將該元素置換到頭指針 i 指向的位置._nArray[i] =_nArray[j].示意圖如下:

首次執行該操作時 i 指針指向處的值實際上就是樞軸的值,此處的操作可以理解為 i 指針指向處的值已在之前被置換到樞軸中,此時, i 指向處已經是一個空位,在此時用找到的小于樞軸的元素填在此處.

4,向后移動頭指針 i ,使其指向從數列頭部算起首個大于樞軸(即14)的元素,并將該元素置換到尾指針 j 指向的位置._nArray[j] =_nArray[i].示意圖如下:

此處同樣可以理解為 j 指針指向處的值已在上一步操作中置換了出去. j 處已是一個空位.

5,如此重復執行步驟3和步驟4,直至 i==j 時結束該循環.

6,退出了該循環后, i 與 j 必定指向同一位置.在該位置的前部元素,其值均小于樞軸.而在該位置的后部元素,其值均大于樞軸.顯而易見,此時 i 和 j 同時指向的位置就應該是樞軸的"新家"._nArray[i]=nPivot.如下圖:

至此,一趟排序結束.待排序數列的首元素將該數列分成了比其小和比其大的兩部分.如下圖:

接著,我們對這一大一小兩部分子數列執行相同的排序操作.

如此"遞歸",直至對整個數列完成排序操作.

以下是c#實現代碼

  

        static void Main(string[] args)        {            Console.WriteLine("請輸入待排序數列(以/",/"分割):");            string _s = Console.ReadLine();            string[] _sArray = _s.Split(",".ToCharArray());            int _nLength = _sArray.Length;            int[] _nArray = new int[_nLength];            for (int i = 0; i < _nLength; i++)            {                _nArray[i] = Convert.ToInt32(_sArray[i]);            }            var list = _nArray.ToList();            QuickSort(list, 0, _nLength - 1);            foreach (var i in list)            {                 Console.WriteLine(i.ToString());            }            while (true)            {                Thread.Sleep(10000);            }       }        //獲取按樞軸值左右分流后樞軸的位置        PRivate static int Division(List<int> list, int left, int right)        {            while (left < right)            {                int num = list[left]; //將首元素作為樞軸                if (num > list[left + 1])                 {                    list[left] = list[left + 1];                    list[left + 1] = num;                    left++;                }                else                {                    int temp = list[right];                    list[right] = list[left + 1];                    list[left + 1] = temp;                    right--;                }                Console.WriteLine(string.Join(",", list));            }            Console.WriteLine("--------------/n");            return left; //指向的此時樞軸的位置        }        private static void QuickSort(List<int> list, int left, int right)        {            if (left < right)            {                int i = Division(list, left, right);                //對樞軸的左邊部分進行排序                QuickSort(list, i + 1, right);                //對樞軸的右邊部分進行排序                QuickSort(list, left, i - 1);            }        }    

  


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲精品二三区| 亚洲第一色在线| 亚洲性日韩精品一区二区| 日韩中文字幕在线视频播放| 日韩大胆人体377p| 91久久国产综合久久91精品网站| 2020欧美日韩在线视频| 亚洲精品国产精品自产a区红杏吧| 成人啪啪免费看| 日本欧美中文字幕| 91精品91久久久久久| 欧美精品精品精品精品免费| 一区二区欧美激情| 国产精品久久一区主播| 国产香蕉精品视频一区二区三区| xxx成人少妇69| 国产精品mp4| www.久久久久| 国自产精品手机在线观看视频| 国产精品三级在线| 欧美亚洲在线观看| 国产一区二区免费| 国产自产女人91一区在线观看| 欧美日韩国产专区| 国产v综合v亚洲欧美久久| 日韩免费在线免费观看| 亚洲人成电影在线观看天堂色| 亚洲国产精品成人av| 亚洲一区制服诱惑| 欧美精品激情视频| 成人免费高清完整版在线观看| 成人久久久久爱| 国产福利精品视频| 日本高清视频精品| 欧美成人精品三级在线观看| 中文字幕日韩av电影| 国产亚洲xxx| 菠萝蜜影院一区二区免费| 亚洲一品av免费观看| 草民午夜欧美限制a级福利片| 日韩欧美精品中文字幕| 久久久久国产视频| 亚洲欧美制服另类日韩| 欧美国产在线电影| 日韩av影片在线观看| 美女扒开尿口让男人操亚洲视频网站| 欧美另类在线播放| 在线精品91av| 国产99在线|中文| 日本中文字幕久久看| 日韩精品亚洲精品| 亚洲精品一区二区久| 丝袜美腿亚洲一区二区| 38少妇精品导航| 亚洲大尺度美女在线| 最近2019中文字幕在线高清| 亚洲最新视频在线| 日韩精品视频观看| 久久久久国产精品www| 久久久久久久久中文字幕| 精品偷拍一区二区三区在线看| 国产一区二区日韩精品欧美精品| 色婷婷av一区二区三区在线观看| 国产精品高清免费在线观看| 中文字幕日韩欧美在线视频| 国产成人涩涩涩视频在线观看| 美女精品久久久| 亚洲国产精品电影| 日韩在线观看你懂的| 91精品国产乱码久久久久久久久| 国产+成+人+亚洲欧洲| 国产综合色香蕉精品| 国产成人福利视频| 欧美日韩高清在线观看| 久久天天躁夜夜躁狠狠躁2022| 日韩欧美aⅴ综合网站发布| 91在线观看免费高清| 国产精品91视频| 亚洲激情 国产| 97国产一区二区精品久久呦| 亚洲精品一区二区三区不| 国产一区二区三区视频在线观看| 欧美日韩国产精品专区| 97久久伊人激情网| 亚洲国产精品成人精品| 欧美情侣性视频| 亚洲女成人图区| 欧美肥老太性生活视频| 91久久精品久久国产性色也91| 国内精品久久久久久久久| 欧美性猛交xxxx| 欧美噜噜久久久xxx| 国产精品日日摸夜夜添夜夜av| 538国产精品视频一区二区| 日韩av免费网站| 97香蕉久久夜色精品国产| 日韩av综合网| 91沈先生作品| 欧美在线性视频| 欧美国产乱视频| 亚洲2020天天堂在线观看| 日韩精品在线观看一区二区| 久久久精品免费| 亚洲成人免费在线视频| 九九精品在线观看| 久久伊人色综合| 韩国一区二区电影| 日韩有码在线视频| 国产高清在线不卡| 久久久久久久久久久国产| 日韩美女av在线| 国产精品爱久久久久久久| 欧美精品一区二区三区国产精品| 亚洲毛片在线观看.| 国产精品欧美风情| 亚洲成**性毛茸茸| 92裸体在线视频网站| 亚洲第一网中文字幕| 欧美激情综合亚洲一二区| 日韩网站免费观看高清| 欧美丝袜一区二区三区| 成人免费观看49www在线观看| 精品国产1区2区| 日韩风俗一区 二区| 亚洲第一区在线观看| 国产玖玖精品视频| 亚洲男人的天堂在线播放| 国产日韩欧美夫妻视频在线观看| 尤物九九久久国产精品的分类| 成人黄色影片在线| 麻豆一区二区在线观看| 视频在线观看99| 欧美日韩久久久久| 久久亚洲精品网站| 福利二区91精品bt7086| 欧美成人精品激情在线观看| 最近2019年中文视频免费在线观看| 亚洲色图av在线| 国产一区二区三区直播精品电影| 国产91在线播放| 91在线免费视频| 成人免费直播live| 国产精品va在线播放| 91免费综合在线| 欧美wwwwww| 成人免费网视频| 668精品在线视频| 国产精品网站大全| 欧美激情中文字幕在线| 日韩av在线直播| 亚洲成人久久电影| 久久久噜噜噜久久中文字免| 精品视频—区二区三区免费| 懂色aⅴ精品一区二区三区蜜月| 国产精品美乳在线观看| 日本a级片电影一区二区| 色婷婷综合久久久久中文字幕1| 欧美日韩国产成人在线| 欧美高跟鞋交xxxxxhd| 亚洲成人国产精品| 大胆人体色综合| 欧美精品在线第一页| 日韩电影免费观看在线| 国产精品久久久久久久9999|