| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 301 人关注过本帖
标题:选择排序哪里有错误
只看楼主 加入收藏
豆zi
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2013-12-9
结帖率:0
收藏
已结贴  问题点数:20 回复次数:2 
选择排序哪里有错误
#include<stdio.h>
#define N 40
int Readscore(int score[]);
void Datasort(int score[],int n);
void printscore(int score[],int n);
int main()
{
    int score[N],n;
    n=Readscore(score);
    printf("total students are %d\n",n);
    Datasort(score,n);
    printf("sorted scores:");
    printscore(score,n);
    return 0;
}
int Readscore(int score[])
{
    int i=-1;
    do{
        i++;
        printf("input score:");
        scanf("%d",&score[i]);
    }while(score[i]>=0);
    return i;
}
    void Datasort(int score[],int n)
    {
        int i,j,k,temp;
        for(i=0;i<n-1;i++)
        {
            k=i;
            for(j=i+1;j<n;j++)
            {
                if(score[j]>score[i])
                {
                    k=j;
                }
            }
            if(k!=i)
            {
                    temp=score[i];
                    score[i]=score[j];
                    score[j]=temp;
                }

    }
    void printscore(int score[],int n)
    {
        int i;
        for(i=0;i<n;i++)
        {
            printf("%4d",score[i]);
        }
        printf("\n");
    }

搜索更多相关主题的帖子: scores return include 
2013-12-09 22:15
韶志
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:斗气大陆
等 级:贵宾
威 望:44
帖 子:2223
专家分:13592
注 册:2013-3-22
收藏
得分:10 
Datasort函数后面少了一个 }

另外你的排序结果好像不对,这个是算法问题,自己改吧

三十年河东,三十年河西,莫欺少年穷!
2013-12-10 11:54
wx1144542900
Rank: 2
等 级:论坛游民
帖 子:24
专家分:10
注 册:2013-11-1
收藏
得分:10 
程序代码:
#include<stdio.h>
#define N 40
int Readscore(int score[]);
void Datasort(int score[],int n);
void printscore(int score[],int n);
int main()
{
    int score[N],n;
    n=Readscore(score);
    printf("total students are %d\n",n);
    Datasort(score,n);
    printf("sorted scores:");
    printscore(score,n);
    return 0;
}
int Readscore(int score[])
{
    int i=-1;
    do{
        i++;
        printf("input score:");
        scanf("%d",&score[i]);
    }while(score[i]>=0&&score[i]<=100);    //这也改了点
    return i;
}
    void Datasort(int score[],int n)
    {
        int i,j,temp;
        for(i=0;i<n-1;i++)
        {
            for(j=i+1;j<n;j++)
            {
                if(score[j]>score[i])
                {
                    temp=score[i];
                    score[i]=score[j];       //这改的有点多,不过我确实看不懂K与J的关系,我就全删了
                    score[j]=temp;
                }
            }
            

        }                                       //少个括号
    }
    void printscore(int score[],int n)
    {
        int i;
        for(i=0;i<n;i++)
        {
            printf("%4d",score[i]);
        }
        printf("\n");
    }
自己试下吧,反正我自己测试的没问题了
2013-12-11 12:53
快速回复:选择排序哪里有错误
数据加载中...
 
   



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

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