| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 466 人关注过本帖
标题:选择法排序,真的不知道错在哪里!!!帮我看看吧
只看楼主 加入收藏
kifine
Rank: 2
等 级:论坛游民
帖 子:48
专家分:49
注 册:2011-5-9
结帖率:80%
收藏
已结贴  问题点数:16 回复次数:5 
选择法排序,真的不知道错在哪里!!!帮我看看吧
#include "stdio.h"
#define N 5

void main()
{
    int p[N];
    int i=0;
    printf("请输入%d个数:\n",N);
    for(i=0;i<N;i++)
        scanf("%d",&p[i]);
    int x,y,m;
    for(x=0;x<N-1;x++)
    {
        m=x;
        for(y=x+1;y<N;y++)
            if(p[m]>p[y])
                m=y;
   
    if(m!=x)
    {
        y=p[x];
        p[x]=p[m];
        p[y]=y;
    }
    }
    printf("排序后的数组:");
    for(i=0;i<N;i++)
        printf("%d  ",p[i]);
}
搜索更多相关主题的帖子: include 
2011-05-10 10:42
ansic
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:恍惚窈冥
等 级:城市猎人
帖 子:1543
专家分:5367
注 册:2011-2-15
收藏
得分:4 
这样试一试
程序代码:
for(x=0;x<N-1;x++){
    for(y=x+1;y<N;y++){
        if(p[x]>p[y]){
            m=p[x];p[x]=p[y];p[y]=m;
        }
    }
}

善人者,不善人之师;不善人者,善人之资。不贵其师,不爱其资,虽智大迷。
2011-05-10 10:48
w123012306
Rank: 9Rank: 9Rank: 9
来 自:湖南
等 级:蜘蛛侠
威 望:4
帖 子:307
专家分:1180
注 册:2010-4-22
收藏
得分:2 
交换值时候,看下传值方向

楼上,楼下的一定要幸福开心哦!
2011-05-10 10:53
kifine
Rank: 2
等 级:论坛游民
帖 子:48
专家分:49
注 册:2011-5-9
收藏
得分:0 
回复 2楼 ansic
你这好像是起泡法吧?
不是的,我想用“选择法”解决
2011-05-10 11:08
wangpenghui
Rank: 2
等 级:论坛游民
帖 子:6
专家分:15
注 册:2011-5-8
收藏
得分:10 
y=p[y];p[y]=y;这两句有问题!第二个p[y]中y等于多少呢,等于数组中的值
2011-05-10 11:10
kifine
Rank: 2
等 级:论坛游民
帖 子:48
专家分:49
注 册:2011-5-9
收藏
得分:0 
回复 5楼 wangpenghui
哦,是我粗心了,连个数据交换都搞错 了
y=p[x];
p[x]=p[m];
p[m]=y;
这下就行了!!!
以后会细心一点的
2011-05-10 11:18
快速回复:选择法排序,真的不知道错在哪里!!!帮我看看吧
数据加载中...
 
   



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

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