zoukankan      html  css  js  c++  java
  • 归并排序-marge-sort

      1、为了解决一些给定的问题,算法要一次或者多次的递归调用自身来解决相关的子问题。这些算法通常采用分治的策略;将源问题划分为规模较小而结构与原问题类似的子问题;递归调用解决这些子问题,然后合并。归并排序算法采用了分治的思想来对数组进行排序。

      2、原理,:把原始数组分成若干子数组,对每一个子数组进行排序,继续把子数组与子数组合并,合并后仍然有序,直到全部合并完,形成有序的数组

    举例

    无序数组[6 2 4 1 5 9]

    先看一下每个步骤下的状态,完了再看合并细节

    第一步 [6 2 4 1 5 9]原始状态

    第二步 [2 6] [1 4] [5 9]两两合并排序,排序细节后边介绍

    第三步 [1 2 4 6] [5 9]继续两组两组合并

    第四步 [1 2 4 5 6 9]合并完毕,排序完毕

    输出结果[1 2 4 5 6 9]

    合并细节

    详细介绍第二步到第三步的过程,其余类似

    第二步:[2 6] [1 4] [5 9]

    两两合并,其实仅合并[2 6] [1 4],所以[5 9]不管它,

    原始状态

    第一个数组[2 6]

    第二个数组[1 4]

    --------------------

    第三个数组[...]

    第1步,顺序从第一,第二个数组里取出一个数字:2和1

    比较大小后将小的放入第三个数组,此时变成下边这样

    第一个数组[2 6]

    第二个数组[4]

    --------------------

    第三个数组[1]

    第2步,继续刚才的步骤,顺序从第一,第二个数组里取数据,2和4,

    同样的比较大小后将小的放入第三个数组,此时状态如下

    第一个数组[6]

    第二个数组[4]

    --------------------

    第三个数组[1 2]

    第3步,再重复前边的步骤变成,将较小的4放入第三个数组后变成如下状态

    第一个数组[6]

    第二个数组[...]

    --------------------

    第三个数组[1 2 4]

    第4步,最后将6放入,排序完毕

    第一个数组[...]

    第二个数组[...]

    --------------------

    第三个数组[1 2 4 6]

    [ 1 2 4 6 ]与[ 5 9 ]的合并过程与上边一样,不再分解

    代码仅供参考

    复制代码
            static void merge(int[] unsorted, int first, int mid, int last, int[] sorted)
            {
                int i = first, j = mid;
                int k = 0;
                while (i < mid && j < last)
                    if (unsorted[i] < unsorted[j])
                        sorted[k++] = unsorted[i++];
                    else
                        sorted[k++] = unsorted[j++];
    
                while (i < mid)
                    sorted[k++] = unsorted[i++];
                while (j < last)
                    sorted[k++] = unsorted[j++];
    
                for (int v = 0; v < k; v++)
                    unsorted[first + v] = sorted[v];
            }
    
            static void merge_sort(int[] unsorted, int first, int last, int[] sorted)
            {
                if (first + 1 < last)
                {
                    int mid = (first + last) / 2;
                    Console.WriteLine("{0}-{1}-{2}", first, mid, last);
                    merge_sort(unsorted, first, mid, sorted);
                    merge_sort(unsorted, mid, last, sorted);
                    merge(unsorted, first, mid, last, sorted);
                }
            }
    
            static void Main(string[] args)
            {
                int[] x = { 6, 2, 4, 1, 5, 9 };
                int[] sorted = new int[x.Length];
                merge_sort(x, 0, x.Length, sorted);
                for (int i = 0; i < sorted.Length; i++)
                {
                    if (x[i] > 0)
                        Console.WriteLine(x[i]);
                }
                Console.ReadLine();
            }

                                        内容参考于http://www.cnblogs.com/kkun/archive/2011/11/23/2260271
  • 相关阅读:
    PHP数组函数(5)
    python3-开发面试题(python)6.24基础篇(3)
    python3开发进阶-Django框架的ORM常用字段和参数
    python3-开发面试题(python)6.23基础篇(2)
    python3 中 and 和 or 运算规律
    python3开发进阶-Django框架中的ORM的常用操作的补充(F查询和Q查询,事务)
    python3-开发面试题(python)6.22基础篇(1)
    python3开发进阶-Django框架中的ORM的常用(增,删,改,查)操作
    python3-os模块中的os.walk(目录树生成器)
    python3开发进阶-Django框架的详解
  • 原文地址:https://www.cnblogs.com/weiliuyby/p/8324851.html
Copyright © 2011-2022 走看看