C#實(shí)現(xiàn)奇偶排序的示例代碼
這篇就從簡(jiǎn)單一點(diǎn)的一個(gè)“奇偶排序”說(shuō)起吧,不過(guò)這個(gè)排序還是蠻有意思的,嚴(yán)格來(lái)說(shuō)復(fù)雜度是 O(N2),不過(guò)在多核的情況下,可以做到 N2 /(m/2)的效率,這里的 m 就是待排序的個(gè)數(shù),當(dāng) m=100,復(fù)雜度為 N2 /50,還行把,比冒泡要好點(diǎn),因?yàn)橹攸c(diǎn)是解決問(wèn)題的奇思妙想。
下面我們看看這個(gè)算法是怎么描述的,既然是奇偶,肯定跟位數(shù)有關(guān)了
- 先將待排序數(shù)組的所有奇數(shù)位與自己身后相鄰的偶數(shù)位相比較,如果前者大于后者,則進(jìn)行交換,直到這一趟結(jié)束。
- 然后將偶數(shù)位與自己身后相鄰的奇數(shù)位相比較,如果前者大于后者,則進(jìn)行交換,直到這一趟結(jié)束。
- 重復(fù) 1,2 的步驟,直到發(fā)現(xiàn)無(wú)“奇偶”,“偶奇” 交換的時(shí)候,就認(rèn)為排序完畢,此時(shí)退出循環(huán)。
① 待排序數(shù)組: 9 2 1 6 0 7
② 所有奇數(shù)位與身后的相鄰的偶數(shù)位比較交換 2 9 1 6 0 7
③ 所有偶數(shù)位與身后的相鄰的奇數(shù)位比較交換 2 1 9 0 6 7
④ 所有奇數(shù)位與身后的相鄰的偶數(shù)位比較交換 1 2 0 9 6 7
⑤ 所有偶數(shù)位與身后的相鄰的奇數(shù)位比較交換 1 0 2 6 9 7
⑥ 所有奇數(shù)位與身后的相鄰的偶數(shù)位比較交換 0 1 2 6 7 9
我們可以看到,經(jīng)過(guò) 5 趟排序后,我們的數(shù)組就排序完畢了,從圖中 ② 可以看到,如果每個(gè)線程分?jǐn)傄粋€(gè)奇數(shù)位,那交換是不是只要一次就夠了呢,可以看到這個(gè)算法在多核處理下面還是很有優(yōu)勢(shì)的。
最后的運(yùn)行代碼:
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Xml.Xsl; namespace ConsoleApplication1 { class Program { static void Main(string[] args) { List<int> list = new List<int>() { 9, 2, 1, 6, 0, 7 }; Console.WriteLine("\n排序前 => " + string.Join(",", list)); list = OddEvenSort(list); Console.WriteLine("\n排序后 => " + string.Join(",", list)); Console.Read(); } static List<int> OddEvenSort(List<int> list) { var isSorted = false; //如果還沒(méi)有排序完,就需要繼續(xù)排序,知道沒(méi)有交換為止 while (!isSorted) { //先默認(rèn)已經(jīng)排序完了 isSorted = true; //先進(jìn)行 奇數(shù)位 排序 for (int i = 0; i < list.Count; i = i + 2) { //如果 前者 大于 后者,則需要進(jìn)行交換操作,也要防止邊界 if (i + 1 < list.Count && list[i] > list[i + 1]) { var temp = list[i]; list[i] = list[i + 1]; list[i + 1] = temp; //說(shuō)明存在過(guò)排序,還沒(méi)有排序完 isSorted = false; } } //再進(jìn)行 奇數(shù)位 排序 for (int i = 1; i < list.Count; i = i + 2) { //如果 前者 大于 后者,則需要進(jìn)行交換操作,也要防止邊界 if (i + 1 < list.Count && list[i] > list[i + 1]) { var temp = list[i]; list[i] = list[i + 1]; list[i + 1] = temp; //說(shuō)明存在過(guò)排序,還沒(méi)有排序完 isSorted = false; } } } return list; } } }
到此這篇關(guān)于C#實(shí)現(xiàn)奇偶排序的示例代碼的文章就介紹到這了,更多相關(guān)C# 奇偶排序內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C#驗(yàn)證控件validator的簡(jiǎn)單使用
這篇文章主要介紹了C#驗(yàn)證控件validator的簡(jiǎn)單使用方法和示例,十分的簡(jiǎn)單實(shí)用,有需要的小伙伴可以參考下。2015-06-06C#中ListView控件實(shí)現(xiàn)窗體代碼
這篇文章主要介紹了C#中ListView控件實(shí)現(xiàn)窗體的核心代碼,非常不錯(cuò),具有參考借鑒價(jià)值,對(duì)c#listview相關(guān)知識(shí)感興趣的朋友一起學(xué)習(xí)吧2016-08-08WinForm實(shí)現(xiàn)跨進(jìn)程通信的方法
這篇文章主要介紹了WinForm實(shí)現(xiàn)跨進(jìn)程通信的方法,通過(guò)一個(gè)WinMessageHelper類實(shí)現(xiàn)這一功能,需要的朋友可以參考下2014-08-08C#簡(jiǎn)單實(shí)現(xiàn)表達(dá)式目錄樹(shù)(Expression)
表達(dá)式目錄樹(shù)以數(shù)據(jù)形式表示語(yǔ)言級(jí)別代碼。數(shù)據(jù)存儲(chǔ)在樹(shù)形結(jié)構(gòu)中。表達(dá)式目錄樹(shù)中的每個(gè)節(jié)點(diǎn)都表示一個(gè)表達(dá)式。這篇文章給大家介紹C#簡(jiǎn)單實(shí)現(xiàn)表達(dá)式目錄樹(shù)(Expression),需要的朋友參考下吧2017-11-11silverlight實(shí)現(xiàn)圖片局部放大效果的方法
這篇文章主要介紹了silverlight實(shí)現(xiàn)圖片局部放大效果的方法,結(jié)合實(shí)例形式分析了silverlight針對(duì)圖片屬性的相關(guān)操作技巧,需要的朋友可以參考下2017-03-03