| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 392 人关注过本帖
标题:新学的归并排序,给参谋一下......有兴趣的自己思考下.......
取消只看楼主 加入收藏
C_戴忠意
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
威 望:2
帖 子:575
专家分:1349
注 册:2011-10-21
结帖率:100%
收藏
 问题点数:0 回复次数:0 
新学的归并排序,给参谋一下......有兴趣的自己思考下.......
程序代码:
#include <stdio.h>

#define MAX 10

int arr[MAX];
int tmp[MAX];

void ComSort(int start,int end)
{
    int i;
    int mid=(start+end)/2;
    int p,q;
    if(start>end||start==end) return;

    printf("START:%d-%d\n",start,end);
    for(i=start;i<=end;i++)

    {
        printf("%d ",arr[i]);
    }
    printf("\n");

    ComSort(start,mid);
    ComSort(mid+1,end);

    p=start;
    q=mid+1;
   

    for(i=start;i<=end;i++)

    {
        tmp[i]=0;
    }
    i=start;
    while(p<=mid&&q<=end)
    {
        if(arr[p]>arr[q])

        {
            tmp[i]=arr[q];
            q++;
        }
        else
        {
            tmp[i]=arr[p];
            p++;
        }
        i++;
    }
    if(p>mid)
    {
        while(q<=end)
        {
            tmp[i]=arr[q];
            i++;
            q++;
        }
    }
    if(q>end)
    {
        while(p<=mid)
        {
            tmp[i]=arr[p];
            i++;
            p++;
        }
    }
    for(i=start;i<=end;i++) arr[i]=tmp[i];

    printf("END:%d-%d\n",start,end);
    for(i=start;i<=end;i++)

    {
        printf("%d ",arr[i]);
    }
    printf("\n");
}

int main()
{
    int i;
    for(i=0;i<MAX;i++) scanf("%d",&arr[i]);
    ComSort(0,MAX-1);
    for(i=0;i<MAX;i++) printf("%d ",arr[i]);
    printf("\n");
    return 0;
}

//23 56 4 67 26 37 76 34 89 35


[ 本帖最后由 C_戴忠意 于 2012-3-30 22:29 编辑 ]
搜索更多相关主题的帖子: start 
2012-03-30 22:25
快速回复:新学的归并排序,给参谋一下......有兴趣的自己思考下.......
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.036447 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved