| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 614 人关注过本帖, 1 人收藏
标题:这个程序好奇怪啊 输入没有上限的 明明看着就有啊 麻烦高手指出哪里错了
只看楼主 加入收藏
sj4004
Rank: 1
等 级:新手上路
帖 子:11
专家分:2
注 册:2010-6-8
收藏(1)
 问题点数:0 回复次数:7 
这个程序好奇怪啊 输入没有上限的 明明看着就有啊 麻烦高手指出哪里错了
源代码:-----明明设了输入学生个数是5啊 运行后发现却是无止境的输入。。。


#include <stdio.h>
#define N 5

struct student
{
    char num[6];
    char name[8];
    int score[3];
} stu[N];

#include <stdio.h>
#define N 5
#define SCORES 5
#define NUMLEN 10
struct std_type{
    char no[NUMLEN];/*学号*/
    char *name;/*名字符串指针*/
    int scores[SCORES];/*五门功课的成绩*/
};
struct std_type students[5];
int order[N];
int total[N];

/*[函数]输入一个学生信息函数*/
int readastu(struct std_type *spt)
{
    int len,j;
    char buf[120];/*输入字符串的缓冲区*/

    printf("\nNumber   :   ");/*输入学号*/
    if(scanf("%s",buf)==1)
        strncpy(spt->no,buf,NUMLEN-1);
    else
        return 0;/*Ctrl+Z结束输入*/
    printf("Name   :   ");/*输入姓名*/
    if(scanf("%s",buf)==1)
    {
        len=strlen(buf);
        spt->name=(char *)malloc(len+1);/*申请存贮姓名的空间*/
        strcpy(spt->name,buf);
    }
    else return 0;/*Ctrl+Z结束输入*/
    printf("Scores   :   ");/*输入成绩*/
    for(j=0;j<SCORES;j++)
        if(scanf("%d",spt->scores+j)!=1)
            break;
            if(j==0)/*一个成绩也未输入*/
            {
                free(spt->name);/*释放存贮姓名的空间*/
                return 0;
            }
            for(;j<SCORES;j++)/*少数未输入的成绩用0分代之*/
                spt->scores[j]=0;
            return 1;
    }

/*[函数]输出一个学生信息的函数*/
int writeastu(struct std_type *spt)
{
    int i;

    printf("Number   :   %s\n",spt->no);/*输出学号*/
    printf("Name     :   %s\n",spt->name);/*输出姓名*/
    printf("Scores   :   ");/*输出成绩*/
    for(i=0;i<SCORES;i++)
        printf("%4d",spt->scores[i]);
    printf("\n\n");
}

main()
{
    int n,i,j,t;

    clrscr();
    for(n=0;readastu(students+n);n++);
    /*采用冒泡法对学生信息数组排序*/
    for(i=0;i<n;i++)
    {
        order[i]=i;/*预置第i个输入的学生*/
        for(t=0,j=0;j<SCORES;j++)/*求第i个学生的总分*/
            t+=students[i].scores[j];
        total[i]=t;
    }
    /*冒泡排序*/
    for(i=0;i<n-1;i++)/*共扫视n-1遍*/
        for(j=0;j<n-1-i;j++)
            if(total[order[j]]<total[order[j+1]])
            {/*交换名次*/
             t=order[j];
             order[j]=order[j+1];
             order[j+1]=t;
            }
    for(j=0;j<n;j++)/*输出*/
        writeastu(students+order[j]);
    printf("\n Press any key to quit...\n");
    getch();
}

搜索更多相关主题的帖子: 输入 麻烦 上限 
2010-08-24 10:23
清风拂晓
Rank: 8Rank: 8
来 自:火星
等 级:蝙蝠侠
威 望:1
帖 子:356
专家分:889
注 册:2010-8-13
收藏
得分:0 
#include <stdio.h>
#define N 5
struct student
{
    char num[6];
    char name[8];
    int score[3];
} stu[N];

这里改成这样试试

清风拂暮(木)
2010-08-24 10:27
sj4004
Rank: 1
等 级:新手上路
帖 子:11
专家分:2
注 册:2010-6-8
收藏
得分:0 
回复 2楼 清风拂晓
大哥 貌似这个和我那个一样啊 没有什么改变啊
2010-08-24 10:45
erikyo
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
威 望:2
帖 子:270
专家分:1154
注 册:2010-6-10
收藏
得分:0 
因为你的这句话有问题:   for(n=0;readastu(students+n);n++);你这句话不会检查输入是否越界,只会不断的输入。
所以你可以不断的输入数据。
加个判断语句即可;
for(n=0;  n < N && readastu(students+n); n++);
2010-08-24 11:03
sj4004
Rank: 1
等 级:新手上路
帖 子:11
专家分:2
注 册:2010-6-8
收藏
得分:0 
回复 4楼 erikyo
我刚刚也试了和你这个的方法差不多 但是我觉得原来的方法也行啊 因为那个for循环语句里面 就是往那个结构数组里面存数据 而数组里面的可存放的元素是有上限的 当超过数组元素的上限for循环应该会自动退出来啊 这个我非常不解
2010-08-24 11:19
御坂美琴
Rank: 11Rank: 11Rank: 11Rank: 11
来 自:魔術の禁書目錄
等 级:小飞侠
威 望:9
帖 子:952
专家分:2929
注 册:2010-8-18
收藏
得分:0 
以下是引用sj4004在2010-8-24 11:19:22的发言:

我刚刚也试了和你这个的方法差不多 但是我觉得原来的方法也行啊 因为那个for循环语句里面 就是往那个结构数组里面存数据 而数组里面的可存放的元素是有上限的 当超过数组元素的上限for循环应该会自动退出来啊 这个我非常不解

如果按你这样说,程序会自动结束这个循环的话,那这个世界怎么还会有这么多的越界和溢出攻击呢?御坂反问道

永远为正义而奋斗,锄强扶弱的Level 5 超能力者
とある魔術の禁書目錄インデックス__御み坂さか美み琴こと
http://bbs.bccn.net/space.php?action=threads&uid=483997
2010-08-24 11:37
erikyo
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
威 望:2
帖 子:270
专家分:1154
注 册:2010-6-10
收藏
得分:0 
楼上说的对,其实这个问题很常见的,编译器其实不会去检查数组是否越界,这个工作只有自己做。
2010-08-24 12:23
sj4004
Rank: 1
等 级:新手上路
帖 子:11
专家分:2
注 册:2010-6-8
收藏
得分:0 
回复 6楼 御坂美琴
哦 知道了 谢谢 我才学C语言不久。。。。
2010-08-24 13:05
快速回复:这个程序好奇怪啊 输入没有上限的 明明看着就有啊 麻烦高手指出哪里错 ...
数据加载中...
 
   



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

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