首頁 後端開發 C#.Net教程 C# 歸併排序

C# 歸併排序

Feb 09, 2017 pm 04:17 PM

 C# 歸併排序

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

using System; 

using System.Collections.Generic; 

using System.Linq; 

using System.Text; 

namespace Sort 

    class MergeSorter 

    

        /// <summary> 

        /// 归并排序之归:归并排序入口  

        /// </summary> 

        /// <param name="data">无序数组</param> 

        /// <returns>有序数组</returns> 

         public static int[] Sort(int[] data) 

        

            //若data为null,或只剩下1 or 0个元素,返回,不排序 

            if (null == data || data.Length <= 1) 

            

                return data; 

            

            //取数组中间下标 

            int middle = data.Length >> 1; 

            //初始化临时数组let,right,并定义result作为最终有序数组,若数组元素奇数个,将把多余的那元素空间预留在right临时数组 

            int[] left = new int[middle]; 

            int[] right =  new int[data.Length - middle]; 

            int[] result = new int[data.Length]; 

            for (int i = 0; i < data.Length; i++) 

            

                if (i < middle) 

                

                    left[i] = data[i]; 

                

                else 

                

                    right[i-middle] = data[i]; //此处i-middle,让我省掉定义一个j,性能有所提高 

                

            

            left = Sort(left);//递归左数组 

            right = Sort(right);//递归右数组 

            result = Merge(left, right);//开始排序 

            return result; 

        

        /// <summary> 

        /// 归并排序之并:排序在这一步 

        /// </summary> 

        /// <param name="a">左数组</param> 

        /// <param name="b">右数组</param> 

        /// <returns>合并左右数组排序后返回</returns> 

         private static int[] Merge(int[] a, int[] b) 

         

            //定义结果数组,用来存储最终结果 

            int[] result = new int[a.Length + b.Length]; 

            int i = 0, j = 0, k = 0; 

            while (i < a.Length && j < b.Length) 

            

                if (a[i] < b[j])//左数组中元素小于右数组中元素 

                

                    result[k++] = a[i++];//将小的那个放到结果数组 

                

                else//左数组中元素大于右数组中元素 

                

                    result[k++] = b[j++];//将小的那个放到结果数组 

                

            

            while (i < a.Length)//这里其实是还有左元素,但没有右元素  

            

                result[k++] = a[i++]; 

            

            while (j < b.Length)//有右元素,无左元素 

            

                result[k++] = b[j++]; 

            

            return result;//返回结果数组 

        

    

}

登入後複製

歸併排序:
歸併(Merge)排序法是將兩個(或兩個以上)有序表合併成一個新的有序表,即把待排序序列分為若干個子序列,分為若干個子序列,分為若干個子序列,每個子序列是有順序的。然後再把有序子序列合併為整體有序序列。此演算法是採用分治法(Divide and Conquer)的一個非常典型的應用。

將已有序的子序列合併,得到完全有序的序列;即先使每個子序列有序,再使子序列段間有序。若將兩個有序表合併成一個有序表,稱為2-路歸併。

假設我們有一個沒有排好序的序列,那麼首先我們使用分割的辦法將這個序列分割成一個一個已經排好序的子序列,然後再利用歸併的方法將一個個的子序列合併成排序好的序列。分割和歸併的過程可以看下面的圖例。

C# 歸併排序


從上圖可以看出,我們先把一個未排序的序列從中間分割成2部分,再把2部分分成4部分,依序分割下去,直到分割成一個的數據,再把這些資料兩兩歸併到一起,使之有序,不停的歸併,最後成為一個排好序的序列。

如何把兩個已經排序好的子序列歸併成一個排好序的序列呢?可以參考下面的方法。

假設我們有兩個已經排序好的子序列。

序列A:1  23  34  65

序列B:2  13  14  87

那麼可以按照下面的步驟將它們歸併到一個序列中。

(1)先設定一個新的數列C[8]。
(2)A[0]和B[0]比較,A[0] = 1,B[0] = 2,A[0] (3) A[1]和B[0]比較,A[1] = 23,B[0] = 2,A[1] > B[0],則C[1] = 2
(4)A[1]和B[1]比較,A[1] = 23,B[1] = 13,A[1] > B[1],則C[2] = 13
(5)A[1]和B[2 ]比較,A[1] = 23,B[2] = 14,A[1] > B[2],則C[3] = 14
(6)A[1]和B[3]比較,A [1] = 23,B[3] = 87,A[1] (7)A[2]和B[3]比較,A[2] = 34,B[3] = 87,A[2] (8)A[3]和B[3]比較,A[3] = 65,B[ 3] = 87,A[3] (9)最後將B[3]複製到C中,則C[7] = 87。歸併完成。 


C#移位運算(左移與右移)


歸併排序,時間複雜度為O(nlogn)。

歸併排序的效率是比較高的,設數列長為N,將數列分開成小數列一共要logN步,每步都是一個合併有序數列的過程,時間複雜度可以記為O(N) ,故一共為O(N*logN)。因為歸併排序每次都是在相鄰的資料中進行操作,所以歸併排序在O(N*logN)的幾種排序方法(快速排序,歸併排序,希爾排序,堆排序)也是效率比較高的。

以上就是 C# 歸併排序的內容,更多相關內容請關注PHP中文網(www.php.cn)!


本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

<🎜>:泡泡膠模擬器無窮大 - 如何獲取和使用皇家鑰匙
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系統,解釋
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆樹的耳語 - 如何解鎖抓鉤
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
<🎜>掩蓋:探險33-如何獲得完美的色度催化劑
2 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1677
14
CakePHP 教程
1430
52
Laravel 教程
1333
25
PHP教程
1278
29
C# 教程
1257
24
c#.net的持續相關性:查看當前用法 c#.net的持續相關性:查看當前用法 Apr 16, 2025 am 12:07 AM

C#.NET依然重要,因為它提供了強大的工具和庫,支持多種應用開發。 1)C#結合.NET框架,使開發高效便捷。 2)C#的類型安全和垃圾回收機制增強了其優勢。 3).NET提供跨平台運行環境和豐富的API,提升了開發靈活性。

C#作為多功能.NET語言:應用程序和示例 C#作為多功能.NET語言:應用程序和示例 Apr 26, 2025 am 12:26 AM

C#在企業級應用、遊戲開發、移動應用和Web開發中均有廣泛應用。 1)在企業級應用中,C#常用於ASP.NETCore開發WebAPI。 2)在遊戲開發中,C#與Unity引擎結合,實現角色控制等功能。 3)C#支持多態性和異步編程,提高代碼靈活性和應用性能。

將C#.NET應用程序部署到Azure/AWS:逐步指南 將C#.NET應用程序部署到Azure/AWS:逐步指南 Apr 23, 2025 am 12:06 AM

如何將C#.NET應用部署到Azure或AWS?答案是使用AzureAppService和AWSElasticBeanstalk。 1.在Azure上,使用AzureAppService和AzurePipelines自動化部署。 2.在AWS上,使用AmazonElasticBeanstalk和AWSLambda實現部署和無服務器計算。

C#和.NET運行時:它們如何一起工作 C#和.NET運行時:它們如何一起工作 Apr 19, 2025 am 12:04 AM

C#和.NET運行時緊密合作,賦予開發者高效、強大且跨平台的開發能力。 1)C#是一種類型安全且面向對象的編程語言,旨在與.NET框架無縫集成。 2).NET運行時管理C#代碼的執行,提供垃圾回收、類型安全等服務,確保高效和跨平台運行。

C#.NET:使用.NET生態系統構建應用程序 C#.NET:使用.NET生態系統構建應用程序 Apr 27, 2025 am 12:12 AM

如何利用.NET構建應用?使用.NET構建應用可以通過以下步驟實現:1)了解.NET基礎知識,包括C#語言和跨平台開發支持;2)學習核心概念,如.NET生態系統的組件和工作原理;3)掌握基本和高級用法,從簡單控制台應用到復雜的WebAPI和數據庫操作;4)熟悉常見錯誤與調試技巧,如配置和數據庫連接問題;5)應用性能優化與最佳實踐,如異步編程和緩存。

.NET框架與C#:解碼術語 .NET框架與C#:解碼術語 Apr 21, 2025 am 12:05 AM

.NETFramework是一個軟件框架,C#是一種編程語言。 1..NETFramework提供庫和服務,支持桌面、Web和移動應用開發。 2.C#設計用於.NETFramework,支持現代編程功能。 3..NETFramework通過CLR管理代碼執行,C#代碼編譯成IL後由CLR運行。 4.使用.NETFramework可快速開發應用,C#提供如LINQ的高級功能。 5.常見錯誤包括類型轉換和異步編程死鎖,調試需用VisualStudio工具。

C#.NET開發:入門的初學者指南 C#.NET開發:入門的初學者指南 Apr 18, 2025 am 12:17 AM

要開始C#.NET開發,你需要:1.了解C#的基礎知識和.NET框架的核心概念;2.掌握變量、數據類型、控制結構、函數和類的基本概念;3.學習C#的高級特性,如LINQ和異步編程;4.熟悉常見錯誤的調試技巧和性能優化方法。通過這些步驟,你可以逐步深入C#.NET的世界,並編寫高效的應用程序。

c#和.net:了解兩者之間的關係 c#和.net:了解兩者之間的關係 Apr 17, 2025 am 12:07 AM

C#和.NET的關係是密不可分的,但它們不是一回事。 C#是一門編程語言,而.NET是一個開發平台。 C#用於編寫代碼,編譯成.NET的中間語言(IL),由.NET運行時(CLR)執行。

See all articles