| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 8130 人关注过本帖
标题:归并排序
只看楼主 加入收藏
BlueGuy
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:29
帖 子:4476
专家分:4055
注 册:2009-4-18
收藏
得分:0 
以下是引用sunyh1999在2011-1-31 08:35:24的发言:

网上看了一篇文章,上面写:
归并排序 排序 50000 个数 耗时:2653 ms
快速排序 排序 50000 个数 耗时:15 ms
像这样的,  明显是 clock() 函数都不知道怎么用的

我就是真命天子,顺我者生,逆我者死!
2011-02-01 04:13
sunyh1999
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:14
帖 子:1178
专家分:3032
注 册:2009-5-17
收藏
得分:0 
今天我又写了一个归并排序双关键字的,但是又有问题,成绩能正确排序,但是有几个学号会变为0:
#include <stdio.h>
#include <stdlib.h>
void merge(int first,int last,int mid,int number[],int score[])
{
    int score_temp[10]={0},number_temp[10]={0};
    int i=first,j=mid+1,k;
    for(k=0;k<=last-first;k++)
    {
    if(i==mid+1)
    {
    score_temp[k]=score[j++];
    number_temp[k]=number[j];
    continue;
    }
    if(j==last+1)
    {
    score_temp[k]=score[i++];
    number_temp[k]=number[i];
    continue;
    }
    if(score[i]<score[j])  score_temp[k]=score[i++],number_temp[k]=number[i];
    else  score_temp[k]=score[j++],number_temp[k]=number[j];
    }
    j=0;
    for(k=first;k<=last;k++,j++)
    {
    score[k]=score_temp[j];
    number[k]=number_temp[j];
    }
}
void merge_sort(int first,int last,int number[],int score[])
{
    int mid=0;
    if(first<last)
    {
    mid=(first+last)/2;
    merge_sort(first,mid,number,score);
    merge_sort(mid+1,last,number,score);
    merge(first,last,mid,number,score);
    }
}
int main()
{
    int number[10]={0},score[10]={0},i,n;
    scanf("%d",&n);
    for(i=0;i<n;i++)
    scanf("%d %d",&number[i],&score[i]);
    merge_sort(0,n-1,number,score);
    printf("\n");
    for(i=0;i<n;i++)
    printf("%d %d\n",number[i],score[i]);
    system("pause");
    return 0;
}

欢迎来到我的博客:http://blog..cn/noisunyuhong
2011-02-01 08:46
点线面
Rank: 8Rank: 8
来 自:NO.-1
等 级:蝙蝠侠
帖 子:525
专家分:980
注 册:2011-1-3
收藏
得分:0 
#include <stdio.h>
#include <stdlib.h>
void merge(int first,int last,int mid,int number[],int score[])
{
    int score_temp[10]={0},number_temp[10]={0};
    int i=first,j=mid+1,k;
    for(k=0;k<=last-first;k++)
    {
    if(i==mid+1)
    {
    score_temp[k]=score[j++];
    number_temp[k]=number[j];
    continue;
    }
    if(j==last+1)
    {
    score_temp[k]=score[i++];
    number_temp[k]=number[i];
    continue;
    }
    if(score[i]<score[j])  score_temp[k]=score[i++],number_temp[k]=number[i];
    else  score_temp[k]=score[j++],number_temp[k]=number[j];
    }
    j=0;
    for(k=first;k<=last;k++,j++)
    {
    score[k]=score_temp[j];
    number[k]=number_temp[j];
    }
}
void merge_sort(int first,int last,int number[],int score[])
{
    int mid=0;
    if(first<last)
    {
    mid=(first+last)/2;
    merge_sort(first,mid,number,score);
    merge_sort(mid+1,last,number,score);
    merge(first,last,mid,number,score);
    }
}
int main()
{
    int number[10]={0},score[10]={0},i,n;
    scanf("%d",&n);
    for(i=0;i<n;i++)
    scanf("%d %d",&number[i],&score[i]);
    merge_sort(0,n-1,number,score);
    printf("\n");
    for(i=0;i<n;i++)
    printf("%d %d\n",number[i],score[i]);
    system("pause");
    return 0;
}
用红色括起来,问题就出在这里,基本错误.
 if(i==mid+1)
    {
    score_temp[k]=score[j++];
    number_temp[k]=number[j];
上面语句不影响下面的语句吗,看清楚 j++

小代码,大智慧
2011-02-01 12:22
sunyh1999
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:14
帖 子:1178
专家分:3032
注 册:2009-5-17
收藏
得分:0 
上面写了j++那么下面不就不需要加了吗?

欢迎来到我的博客:http://blog..cn/noisunyuhong
2011-02-01 13:13
sunyh1999
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:14
帖 子:1178
专家分:3032
注 册:2009-5-17
收藏
得分:0 
回复 33楼 点线面
我改过了,为什么结果还是错误的?

欢迎来到我的博客:http://blog..cn/noisunyuhong
2011-02-01 13:20
点线面
Rank: 8Rank: 8
来 自:NO.-1
等 级:蝙蝠侠
帖 子:525
专家分:980
注 册:2011-1-3
收藏
得分:0 
你尝试只有学号,没有成绩,或者只有成绩,没有学号,看一看有什么问题.

[ 本帖最后由 点线面 于 2011-2-1 13:24 编辑 ]

小代码,大智慧
2011-02-01 13:23
sunyh1999
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:14
帖 子:1178
专家分:3032
注 册:2009-5-17
收藏
得分:0 
什么意思?

欢迎来到我的博客:http://blog..cn/noisunyuhong
2011-02-01 13:38
点线面
Rank: 8Rank: 8
来 自:NO.-1
等 级:蝙蝠侠
帖 子:525
专家分:980
注 册:2011-1-3
收藏
得分:0 
我意思是将一个综合程序分开为独立成绩程序与独立学号程序,看一看是那部分出了问题,明白吗?

小代码,大智慧
2011-02-01 13:48
sunyh1999
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:14
帖 子:1178
专家分:3032
注 册:2009-5-17
收藏
得分:0 
写好了且测试数据过了,问题在于j++上,要先算再+
#include <stdio.h>
#include <stdlib.h>
void merge(int first,int last,int mid,int number[],int score[])
{
    int score_temp[10]={0},number_temp[10]={0};
    int i=first,j=mid+1,k;
    for(k=0;k<=last-first;k++)
    {
    if(i==mid+1)
    {
    score_temp[k]=score[j];
    number_temp[k]=number[j];
    j++;
    continue;
    }
    if(j==last+1)
    {
    score_temp[k]=score[i];
    number_temp[k]=number[i];
    i++;
    continue;
    }
    if(score[i]<score[j])  score_temp[k]=score[i],number_temp[k]=number[i],i++;
    else if(score[i]==score[j]&&number[i]>number[j])  score_temp[k]=score[i],number_temp[k]=number[i],i++;
    else
    score_temp[k]=score[j],number_temp[k]=number[j],j++;
    }
    j=0;
    for(k=first;k<=last;k++,j++)
    {
    score[k]=score_temp[j];
    number[k]=number_temp[j];
    }
}
void merge_sort(int first,int last,int number[],int score[])
{
    int mid=0;
    if(first<last)
    {
    mid=(first+last)/2;
    merge_sort(first,mid,number,score);
    merge_sort(mid+1,last,number,score);
    merge(first,last,mid,number,score);
    }
}
int main()
{
    int number[10]={0},score[10]={0},i,n;
    scanf("%d",&n);
    for(i=0;i<n;i++)
    scanf("%d %d",&number[i],&score[i]);
    merge_sort(0,n-1,number,score);
    printf("\n");
    for(i=0;i<n;i++)
    printf("%d %d\n",number[i],score[i]);
    system("pause");
    return 0;
}

欢迎来到我的博客:http://blog..cn/noisunyuhong
2011-02-01 16:08
点线面
Rank: 8Rank: 8
来 自:NO.-1
等 级:蝙蝠侠
帖 子:525
专家分:980
注 册:2011-1-3
收藏
得分:0 
我表达就是这个意思

小代码,大智慧
2011-02-01 16:13
快速回复:归并排序
数据加载中...
 
   



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

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