标题:这个代码到底哪里出错了……求解。
只看楼主
mengt2012
Rank: 1
等 级:新手上路
帖 子:16
专家分:0
注 册:2014-8-8
 问题点数:0 回复次数:3 
这个代码到底哪里出错了……求解。
程序代码:
//paixu_1.c -- 插入排序法程式
#include <stdio.h>
#define MAXAMOUNT 100

int main(void)
{
    int i, k;
    int current;
    int class[MAXAMOUNT];
    int amount;

    scanf("%d", &amount);    //输入需要排序的个数
    for ( i=0; i<amount; i++) {
        scanf("%d", &class[i]);
    }
    for ( i=1; i<amount; i++) {
        current = class[i];
    }
    for ( k=i-1; k>=0; k--) {
        if ( current>class[k] ) {
            class[k+1] = class[k];
        } else break;    //必须跳出来
        class [k+1] = class[k];
    }
    
    printf("\n");
    for ( i=0; i<amount; i++) {
        printf("%d\t", class[i]);
    }

    return 0;
}


如果有一班学生欲按高矮顺序排成一排, 设第1 位至第i-1 位学生都已经排好了, 欲排第i 位, 我们可由第i-1 位开始比起, 如果比第i-1 位高, 则与第i-1 位对调, 再往前比。 否则排下一位学生, 即第i+1 学生。

搞不懂程序哪里出错了……
搜索更多相关主题的帖子: current include amount color 
2014-10-19 14:31
wssy213
Rank: 12Rank: 12Rank: 12
来 自:湖南
等 级:贵宾
威 望:10
帖 子:967
专家分:3703
注 册:2014-6-6
得分:0 
逻辑上的错误。自己把算法用伪代码写出来,多推敲几遍,然后在上机敲代码。

坚持----------------------------------唯一的道路
shit ! ! !
2014-10-19 14:52
soulmate1023
Rank: 8Rank: 8
等 级:蝙蝠侠
威 望:6
帖 子:256
专家分:831
注 册:2014-9-23
得分:0 
最重要的错是你用class定义数组名,这个是C++中的类的关键字,一些C编译器都是兼容C++的,你这样写不规范。
其二,你有几处括号使用位置不当,看出你没有细心再敲代码:
我帮你改了几处,你参考下:
程序代码:
#include <stdio.h>
int main()
{
    int i,k;
    int current,class1[100];
    int amount;

    scanf("%d", &amount);    //输入需要排序的个数
    for ( i=0; i<amount; i++) {
        scanf("%d", &class1[i]);
    }
    for ( i=1; i<amount; i++) {
        current=class1[i];
  
    for ( k=i-1; k>=0; k--) {
        if ( current>class1[k] ) {
            class1[k+1]=class1[k];
            class1[k]=current;
        } 
        else break;    //必须跳出来
       }
       }
    
    printf("\n");
    for ( i=0; i<amount; i++) {
        printf("%d ", class1[i]);
    }
return 0;
}
2014-10-19 15:17
erty1001
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
威 望:4
帖 子:331
专家分:1433
注 册:2014-8-31
得分:0 
程序代码:
简单说说:
代码有条理 才是好工作


#include <stdio.h>
int main()
{
    //=============================================初始化
    int i,k;
    int current,class1[100];
    int amount;
    //=============================================


    //=============================================输入
    scanf("%d", &amount);    //输入需要排序的个数
    for ( i=0; i<amount; i++)
    {
        scanf("%d", &class1[i]);
    }
    //=============================================

    //=============================================排序
    for ( i=1; i<amount; i++)
    {
        current=class1[i]; 
        for ( k=i-1; k>=0; k--)
        {
            if ( current>class1[k] )
            {class1[k+1]=class1[k];class1[k]=current;}
        }
    }
    //=============================================

    //=============================================输出
    printf("\n");
    for ( i=0; i<amount; i++)
    {
        printf("%d ", class1[i]);
    }
    //=============================================

    return 0;
}
2014-10-19 16:43



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-437425-1-1.html




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

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