| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 380 人关注过本帖
标题:堆排序,我不知道错哪了,求助各位大牛
只看楼主 加入收藏
Jean_hua
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2011-4-4
结帖率:100%
收藏
已结贴  问题点数:20 回复次数:4 
堆排序,我不知道错哪了,求助各位大牛
#include <stdio.h>
typedef struct
{
   int  key;
}rec;
typedef  rec sqlist[30];

void sift(sqlist r,int s,int m)
{
    int j=2*s;
    rec x;
    x=r[s];
    for(j=2*s;j<=m;j=s*2)
    {
    if(j<m&&(r[j].key<r[j+1].key))
        ++j;
    //q++;    if(!(x.key<r[j].key)) break;
    r[s]=r[j];s=j;    }
    r[s]=x;

}

void heapsort(sqlist &r,int m)
{
    int i;
    rec w;
    for(i=m/2;i>=1;i--)
        sift(r,i,m);
    for(i=m;i>=2;i--)
    {
        w=r[i];r[i]=r[1];
        r[1]=w;
        sift(r,1,i-1);
    }
}
void main()
{
   
    sqlist  s;
    int i,n;
    scanf("%d",&n);
    for(i=0;i<n;i++)
        scanf("%d",&s[i].key);
    heapsort(s,n);

    for(i=0;i<n;i++)
        printf("%d ",s[i].key);

    printf("\n");


}
2011-06-17 23:28
yuccn
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:何方
等 级:版主
威 望:167
帖 子:6815
专家分:42393
注 册:2010-12-16
收藏
得分:7 
华帅,加油啊
O(∩_∩)O哈哈~

我行我乐
公众号:逻辑客栈
我的博客:
https://blog.yuccn. net
2011-06-18 11:07
Jean_hua
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2011-4-4
收藏
得分:0 
好好看看么
2011-06-18 16:05
inta
Rank: 1
等 级:新手上路
帖 子:1
专家分:7
注 册:2011-6-18
收藏
得分:7 
事先声明,我没看懂您的程序,我只是把程序提示的错误改掉了,改的不对还请见谅。
#include <stdio.h>
typedef struct
{
   int  key;
}rec;
typedef  rec sqlist[30];

void sift(sqlist r,int s,int m)
{
    int j=2*s;
    rec x;
    x=r[s];
    for(j=2*s;j<=m;j=s*2)
    {
    if(j<m&&(r[j].key<r[j+1].key))
        ++j;
    //*q++;    if(!(x.key<r[j].key)) break;*//
    r[s]=r[j];s=j;    }
    r[s]=x;

}

void heapsort(sqlist r,int m)//*&r改为r,因为typedef rec sqlist[30]已给30个元素的结构体数组命了一个新名*//
{
    int i;
    rec w;
    for(i=m/2;i>=1;i--)
        sift(r,i,m);
    for(i=m;i>=2;i--)
    {
        w=r[i];r[i]=r[1];
        r[1]=w;
        sift(r,1,i-1);
    }
}
void main()
{
   
    sqlist  s;
    int i,n;
    scanf("%d",&n);
    for(i=0;i<n;i++)
        scanf("%d",&s[i].key);
    heapsort(s,n);

    for(i=0;i<n;i++)
        printf("%d ",s[i].key);

    printf("\n");


}
2011-06-19 11:53
naruto01
Rank: 4
等 级:业余侠客
帖 子:103
专家分:280
注 册:2011-5-23
收藏
得分:7 
肤浅一看函数参数的传递上需要区别下  到底用sqlist[30] 还是 rec

算法就pass了
2011-06-19 14:58
快速回复:堆排序,我不知道错哪了,求助各位大牛
数据加载中...
 
   



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

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