niusouti.com

下列给定程序中,函数fun()的功能是:对N名学生的学习成绩,按从低到高的顺序找出前m(m≤10)名学生来,并将这些学生数据存放在一个动态分配的连续存储区中,此存储区的首地址作为函数值返回。请改正程序中的错误,使它能得到正确结果。注意:不要改动main函数,不得增行或删行,也不得更改程序的结构。试题程序:include <conio.h>include <string.h>include <stdio.h>include <alloc.h>define N 10typedef struct SS{char

题目

下列给定程序中,函数fun()的功能是:对N名学生的学习成绩,按从低到高的顺序找出前m(m≤10)名学生来,并将这些学生数据存放在一个动态分配的连续存储区中,此存储区的首地址作为函数值返回。

请改正程序中的错误,使它能得到正确结果。

注意:不要改动main函数,不得增行或删行,也不得更改程序的结构。

试题程序:

include <conio.h>

include <string.h>

include <stdio.h>

include <alloc.h>

define N 10

typedef struct SS

{

char num[10];

int s;

}STU;

STU *fun(STU a[],int m)

{

STU b[N],*t;

int i, j,k;

/*************found*************/

*t=calloc(m,sizeof(STU));

for(i=0;i<N;i++)

b[i]=a[i];

for(k=0;k<m;k++)

{

/*************found*************/

for(i=j=0;i<N;j++)

if(b[i].s<b[j],s)

j=i;

/*************found*************/

t[k].s=b[j].s;

b[j].s=100;

}

return t;

}

outresult(STU a[],FILE *pf)

{

int i;

for(i=0;i<N;i++)

fprintf(pf,"NO=%S Mark=%d\n",

a[i].num,a[i].S);

fprintf(pf,"\n\n");

}

main()

{

STU a[N]={{“A01”,77},{“A02”,85},

{“A03”,96},{“A04”,65},{“A05”,75},

{“A06”,96},{“A07”,76},{“A08”,63},

{“A09”,69},{“A10”,78}};

STU *porder;

int i,m;

clrscr();

printf(“*****THE RESULT*****\n”);

outresult(a,stdout);

printf(“\nGive the number of the students who have lower score:”);

scanf(“%d”,&m);

while(m>10)

{

printf(“\nGive the number of the students who have lower score:”);

scanf(“%d”,&m);

}

porder=fun(a,m);

printf(“*****THE RESULT*****\n”);

printf(“The low:\n”);

for(i=0;i<m;i++)

printf(“%s %d\n”,porder[i].num,

porder[i].s);

free(porder);

}


相似考题

1.●试题四下列给定程序中,函数fun()的功能是:对N名学生的学习成绩,按从高到低的顺序找出前m(m≤10)名学生来,并将这些学生数据存放在一个动态分配的连续存储区中,此存储区的首地址作为函数值返回。注意:部分源程序给出如下。请勿改动主函数main和其他函数中的任何内容,仅在函数fun()的横线上填入所编写的若干表达式或语句。试题程序:#include<stdio.h>#include<malloC.h>#include<string.h>#include<conio.h>#define N 10typedef struct ss{char num[10];int order;}STU;STU *fun(STU a[], int m){STU b[N],*tt;int i,j,k;(1) ;for(i=0; i<N; i++)b[i]=a[i];for (k=0;k<m;k++){for(i=j=0;i<N;i++)if ( (2) )j=i;tt[k]=b[j];b[j].order=0;}return (3) ;}outresult(STU a[],FILE *pf){int i;for(i=0;i<N; i++)fprintf(pf,"No=%s Mark=%d\n",a[i].num,a[i].order);fprintf(pf,"\n\n");}main(){STU [N]={{"A01",80},{"A02",79},{"A03",66},{"A04",82},{"A05",87},{"A06",93},{"A07",78},{"A08",60},{"A09",85},{"A10",73}};STU *p_order;int i,m;clrscr();printf("*** The Origial data ***\n");outresult(a, stdout);printf("\nGive the numeber of thestudents who have better score:");scanf("%d",&m);while (m>10){printf("\nGive the number of thestudets who have better score:");scanf("%d",&m);}p_order=fun(a,m);printf("*** THE RESULT ***\n");printf("*** The top students ***\n");for(i=0; i<m; i++)printf(" %s %d\n",p_order[i].num,p_order[i].order);free(p_order);}

2.下列给定程序中,函数fun()的功能是:对N名学生的学习成绩,按从高到低的顺序找出前叫m≤10)名学生来,并将这些学生数据存放在一个动态分配的连续存储区中,此存储区的首地址作为函数值返回。请改正程序中的错误,使它能得出正确的结果。注意:不要改动main函数,不得增行或删行,也不得更改程序的结构.试题程序:include <conio.h>include <string.h>include <stdio.h>include <alloc.h>define N 10typedef struct ss{char num[10];int s;} STU;STU *fun{STU a[], int m){ STU b[N] ,*t;int i, j,k;/*************found**************/*t=calloc (m, slzeof (STU));for(i=0;i<N;i++) b[i]=a[i];for(k=0; k<m; k++){ for (i=j=0;i<N;i++)if (b[i].s>b[j].s) j=i;/*************found**************/t[k].num=b [j].num;t[k].s=b[j] s;b[j].s=0;}return t;}outresult(STU a[],FILE *pf){ int i;for (i=0; i<N; i++)fprintf(pf, "No=%s Mark-%d\n ",a [i] .num, a[i].s);fprintf(pf, "\n\n ");}main ( ){ STU a[N]={{ "A01 ",81},{ "A02 ",89},{ "A03 ",66},{ "A04 ",87},{ "A05 ",77},{ "A06 ",90},{ "A07 ",79},{ "A08 ",61},{ "A09 ",80},{ "Al0 ",71}};STU *pOrder;int i, m;clrscr ();printf ("*****THE RESULT***** \n");outresult (a, stdout);printf ("\nGive the number of the studentswho have better score: ");scanf ("%d", &m);while (m>10){ printf("lnGive the number of thestudents who have better score: ");scanf ("%d", %m);pOrder=fun (a,m);printf("***** THE RESULT*****kn");printf("The top :\n");for (i=0; i<m; i++)printf("%s %d\n",pOrder[i].num,p0rder [i]. s);free (pOrder);}

更多“下列给定程序中,函数fun()的功能是:对N名学生的学习成绩,按从低到高的顺序找出前m(m≤10)名学生来 ”相关问题
  • 第1题:

    给定程序MODll.C中,函数fun的功能是:在有n名学生,2门课成绩的结构体数组std中,计算出第l门课程的平均分,作为函数值返回。例如,主函数中给出了4名学生的数据,则程序运行的结果为:第l门课程的平均分是:76.125000

    请改正函数fun中指定部位的错误,使它能得出正确的结果。

    注意:不要改动main函数,不得增行或删行,也不得更改程序的结构。试题程序:


    正确答案:
    (1)doublesum改为doublesunl=0.0;(2)for(i=0;i<2;i*)改为细(i=0;i<n;i++);(3)sum+=ad[i].scom[1]改为sum+=羽[i].score[0];【考点分析】主要考察桩时变量初始化,c语言里临时变量不初始化,它的默认值是不确定的一个值。再者,考察C语言约定数组的下标是从0开始的。【解题思路】(1)doubleⅫ改为double8am=0.0;累加求和需要初始化累加结果的临时变量。(2)for(i_0;i<2;i++)改为for(i_0;i<n;i++);共有11个学生的成绩,需要累加所有学生第一门课的成绩。(3)sum+.std[i].BCOl.e[1]改为8am+=8td[i].score[0];第1门课程的平均分,c语言的下标是从0开始的。

  • 第2题:

    给定程序MODll.C中函数fun的功能是:对N名学生的学习成绩,按从高到低的顺序找出前m(m≤10)名学生来,并将这些学生数据存放在一个动态分配的连续存储区中,此存储区的首地址作为函数值返回。

    请改正函数fun中指定部位的错误,使它能得出正确的结果。

    注意:不要改动main函数,不得增行或删行,也不得更改程序的结构!


    正确答案:(1)t=(STU*)calloc(sizeof(sTu)m); (2)t[k]=b[j];
    (1)t=(STU*)calloc(sizeof(sTu),m); (2)t[k]=b[j]; 解析:本题中函数的功能是按学习成绩从高到低的顺序找出前m(m≤10)名学生。利用循环结构实现对定义的结构体中的成绩域进行排序。

  • 第3题:

    某校按字母A到Z的顺序给班级编号,按班级编号加01、02、03,…,给每位学生按顺序定学号,若A-K班级人数从15人起每班递增1名,之后每班按编号顺序递减2名,则第256名学生的学号是多少?( )
    A. M12 B. N11 C. N10 D. M13


    答案:D
    解析:
    根据题意,本题考查等差数列的求和,K是第11个字母,那么,A班有15人,K班有15 + 10 = 25(人),前面A-K班一共有,剩下256-220=36(人)排到K后面的班级,L班按照题意排23人,剩下13人到M班,因此最后一个学生的编号为M13。

  • 第4题:

    已知学生的记录由学号和学习成绩构成,N名学生的数据已存入a结构体数组中。请编写函数fun,函数的功能是:找出成绩最低的学生记录,通过形参返回主函数(规定只有一个最低分)。

    注意:部分源程序存在文件PROGl.C文件中。

    请勿改动主函数main和其他函数中的任何内容,仅在函数fun的莅括号中填入你编写的若干语句。


    正确答案:
    解析:该程序功能是求最低分数的学生。本题是关于求解结构体中某些成员的最小值,首先将第一个值设定为最小值,并在循环中将其他所有值与该值进行比较,求得最小值。

  • 第5题:

    下列给定程序中,函数proc()的功能是:对M名学生的学习成绩,按从低到高的顺序找出前m(m≤10)名学生来,并将这些学生数据存放在一个动态分配的连续存储区中,此存储区的首地址作为函数值返回。

    请修改程序中的错误,使它能得到正确结果。

    注意:不要改动main()函数,不得增行或删行,也不得更改程序的结构。

    试题程序:


    正确答案:

    (1)错误:*t=calloe(m,sizeof(STU));
    正确:(structss*)calloc(m,sizeof(STU));
    (2)错误:for(i=j=0;i<M;j++)
    正确:for(i=j=0;i<M;i++)
    (3)错误:t[k].s=b[j].s;
    正确:t[k]=b[j];
    【解析】由函数proc()可知,变量t是指向动态存储空间的变量,因此不能间接访问运算符,而函数calloc的返回值类型为void*,要进行显式类型转换,因此“*t=calloc(m,si-zeof(STU));”应改为“(structss*)calloc(m,sizeof(STU));”。
    由程序可知,变量i为控制学生个数的变量,因此“for(i=j=