欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C#實現(xiàn)奇偶排序的示例代碼

 更新時間:2023年11月27日 14:31:21   作者:神仙別鬧  
奇偶排序是一種簡單的排序算法,該算法通過比較并交換相鄰的元素來完成排序,本文主要介紹了C#實現(xiàn)奇偶排序的示例代碼,具有一定的參考價值,感興趣的可以了解一下

這篇就從簡單一點的一個“奇偶排序”說起吧,不過這個排序還是蠻有意思的,嚴格來說復雜度是 O(N2),不過在多核的情況下,可以做到 N2 /(m/2)的效率,這里的 m 就是待排序的個數(shù),當 m=100,復雜度為 N2 /50,還行把,比冒泡要好點,因為重點是解決問題的奇思妙想。
下面我們看看這個算法是怎么描述的,既然是奇偶,肯定跟位數(shù)有關(guān)了

  • 先將待排序數(shù)組的所有奇數(shù)位與自己身后相鄰的偶數(shù)位相比較,如果前者大于后者,則進行交換,直到這一趟結(jié)束。
  • 然后將偶數(shù)位與自己身后相鄰的奇數(shù)位相比較,如果前者大于后者,則進行交換,直到這一趟結(jié)束。
  • 重復 1,2 的步驟,直到發(fā)現(xiàn)無“奇偶”,“偶奇” 交換的時候,就認為排序完畢,此時退出循環(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)過 5 趟排序后,我們的數(shù)組就排序完畢了,從圖中 ② 可以看到,如果每個線程分攤一個奇數(shù)位,那交換是不是只要一次就夠了呢,可以看到這個算法在多核處理下面還是很有優(yōu)勢的。
最后的運行代碼:

 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;
 
             //如果還沒有排序完,就需要繼續(xù)排序,知道沒有交換為止
             while (!isSorted)
             {
                 //先默認已經(jīng)排序完了
                 isSorted = true;
 
                 //先進行 奇數(shù)位 排序
                 for (int i = 0; i < list.Count; i = i + 2)
                 {
                     //如果 前者 大于 后者,則需要進行交換操作,也要防止邊界
                     if (i + 1 < list.Count && list[i] > list[i + 1])
                     {
                         var temp = list[i];
                         list[i] = list[i + 1];
                         list[i + 1] = temp;
 
                         //說明存在過排序,還沒有排序完
                         isSorted = false;
                     }
                 }
 
                 //再進行 奇數(shù)位 排序
                 for (int i = 1; i < list.Count; i = i + 2)
                 {
                     //如果 前者 大于 后者,則需要進行交換操作,也要防止邊界
                     if (i + 1 < list.Count && list[i] > list[i + 1])
                     {
                         var temp = list[i];
                         list[i] = list[i + 1];
                         list[i + 1] = temp;
 
                         //說明存在過排序,還沒有排序完
                         isSorted = false;
                     }
                 }
             }
 
             return list;
         }
     }
 }

到此這篇關(guān)于C#實現(xiàn)奇偶排序的示例代碼的文章就介紹到這了,更多相關(guān)C# 奇偶排序內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C#中如何生成安裝包

    C#中如何生成安裝包

    這篇文章主要介紹了C#中如何生成安裝包問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • C#驗證控件validator的簡單使用

    C#驗證控件validator的簡單使用

    這篇文章主要介紹了C#驗證控件validator的簡單使用方法和示例,十分的簡單實用,有需要的小伙伴可以參考下。
    2015-06-06
  • C#中ListView控件實現(xiàn)窗體代碼

    C#中ListView控件實現(xiàn)窗體代碼

    這篇文章主要介紹了C#中ListView控件實現(xiàn)窗體的核心代碼,非常不錯,具有參考借鑒價值,對c#listview相關(guān)知識感興趣的朋友一起學習吧
    2016-08-08
  • C#開發(fā)WPF程序中的弱事件模式

    C#開發(fā)WPF程序中的弱事件模式

    這篇文章介紹了C#開發(fā)WPF程序中的弱事件模式,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-06-06
  • WinForm實現(xiàn)跨進程通信的方法

    WinForm實現(xiàn)跨進程通信的方法

    這篇文章主要介紹了WinForm實現(xiàn)跨進程通信的方法,通過一個WinMessageHelper類實現(xiàn)這一功能,需要的朋友可以參考下
    2014-08-08
  • C#實現(xiàn)登錄窗口(不用隱藏)

    C#實現(xiàn)登錄窗口(不用隱藏)

    C#登錄窗口的實現(xiàn),特點就是不用隱藏,感興趣的朋友不要錯過
    2013-11-11
  • c#如何使用UDP進行聊天通信

    c#如何使用UDP進行聊天通信

    這篇文章主要介紹了c#如何使用UDP進行聊天通信問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • C#簡單實現(xiàn)表達式目錄樹(Expression)

    C#簡單實現(xiàn)表達式目錄樹(Expression)

    表達式目錄樹以數(shù)據(jù)形式表示語言級別代碼。數(shù)據(jù)存儲在樹形結(jié)構(gòu)中。表達式目錄樹中的每個節(jié)點都表示一個表達式。這篇文章給大家介紹C#簡單實現(xiàn)表達式目錄樹(Expression),需要的朋友參考下吧
    2017-11-11
  • C#編程中設置程序只可被運行一次的方法

    C#編程中設置程序只可被運行一次的方法

    這篇文章主要介紹了C#編程中設置程序只可被運行一次的方法,包括一種讓程序自動重啟以限制第二次被運行的方法,需要的朋友可以參考下
    2015-11-11
  • silverlight實現(xiàn)圖片局部放大效果的方法

    silverlight實現(xiàn)圖片局部放大效果的方法

    這篇文章主要介紹了silverlight實現(xiàn)圖片局部放大效果的方法,結(jié)合實例形式分析了silverlight針對圖片屬性的相關(guān)操作技巧,需要的朋友可以參考下
    2017-03-03

最新評論