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

           归并排序就是把数组A分成2个数组A1和A2,再对A1和A2也分别平分,直到不能分为止,即只有1个元素了.再依次合并.是一个分和合的过程.

           代码是在ubuntu下的vim里写的.我加了很多打印,从打印结果里面可以看出程序是怎么一步一步执行的,本来要画个图的,因为没找到比较好的工具(ubuntu下),比较好是说可以画的漂亮,而且有剪切功能.

    #include<stdio.h>
    #include<malloc.h>
    
    
    void mergesort(int source[], int ordered[], int startIndex, int endIndex);
    void merge(int source[], int ordered[], int startIndex, int midIndex, int endIndex);
    
    
    int main()
    {
            int a[8] = {3,2,1,6,7,4,8,5};
            int b[8];
        int i;
        printf("排序前的乱序数组:");
        for(i = 0; i < 8; ++i)
            printf("%d ",a[i]);
        printf("
    
    ");
    
            mergesort(a,b,0,7);
    
            printf("排序后的有序数组:");
        for(i = 0; i < 8; ++i)
                    printf("%d ",b[i]);
            printf("
    ");
    
            return 0;
    }
    
    void mergesort(int source[], int ordered[], int startIndex, int endIndex)
    {
        if(startIndex == endIndex)
        {
            ordered[startIndex] = source[startIndex];
        }
        else
        {
            int *tmp = (int*)malloc((endIndex-startIndex+1)*sizeof(int));
            int mid = (startIndex + endIndex)/2;
            printf("(startIndex,midIndex,endIndex) = ");
            printf("(%d,%d,%d)
    ",startIndex,mid,endIndex);
            mergesort(source,tmp,startIndex,mid);
            mergesort(source,tmp,mid+1,endIndex);
            
            printf("需要排序的两个数组是:");
            
            int i;
            for(i = startIndex; i <= endIndex; ++i)
            {    
                printf("%d ",tmp[i]);
                if(i == mid)
                    printf("");
            }
            printf("
    ");
            //保证用来合并的数组有序,所以第一个参数是tmp.
            merge(tmp,ordered,startIndex,mid,endIndex);
        }
    }
    
    void merge(int source[], int ordered[], int startIndex, int midIndex, int endIndex)
    {
        int i = startIndex, j = midIndex + 1,k = startIndex;
        while(i <= midIndex && j <= endIndex)
        {
            
            if(source[i] < source[j])
            {
                ordered[k++] = source[i++];
            }
            else
            {    
                ordered[k++] = source[j++];
            }
        }
    
        while(i<=midIndex)
            ordered[k++] = source[i++];
    
        while(j<=endIndex)
            ordered[k++] = source[j++];
    
        printf("合并后的结果是:");
        for(i = startIndex; i <= endIndex; ++i)
            printf("%d ",ordered[i]);
        printf("
    
    ");
    }

    编译结果:

    排序前的乱序数组:3 2 1 6 7 4 8 5 
    
    (startIndex,midIndex,endIndex) = (0,3,7)
    (startIndex,midIndex,endIndex) = (0,1,3)
    (startIndex,midIndex,endIndex) = (0,0,1)
    需要排序的两个数组是:32 
    合并后的结果是:2 3 
    
    (startIndex,midIndex,endIndex) = (2,2,3)
    需要排序的两个数组是:16 
    合并后的结果是:1 6 
    
    需要排序的两个数组是:2 31 6 
    合并后的结果是:1 2 3 6 
    
    (startIndex,midIndex,endIndex) = (4,5,7)
    (startIndex,midIndex,endIndex) = (4,4,5)
    需要排序的两个数组是:74 
    合并后的结果是:4 7 
    
    (startIndex,midIndex,endIndex) = (6,6,7)
    需要排序的两个数组是:85 
    合并后的结果是:5 8 
    
    需要排序的两个数组是:4 75 8 
    合并后的结果是:4 5 7 8 
    
    需要排序的两个数组是:1 2 3 64 5 7 8 
    合并后的结果是:1 2 3 4 5 6 7 8 
    
    排序后的有序数组:1 2 3 4 5 6 7 8 

    从打印结果可以自己手动执行归并排序的过程了吧?

  • 相关阅读:
    php开发_图片验证码
    php开发_php环境搭建
    中序线索二叉树算法
    WPF技巧(1)异步绑定
    WPF技巧(2)绑定到附加属性
    nhibernate 抓取策略
    wpf 控件开发基础(6) 单一容器(Decorator)
    WPF技巧(3)监测属性变更
    Caliburn v2 变更启动初始化
    wpf单容器中的Chrome
  • 原文地址:https://www.cnblogs.com/HpuAcmer/p/4113867.html
Copyright © 2011-2022 走看看