- 2022-04-09 发布 |
- 37.5 KB |
- 140页
文档介绍
《C语言程序设计》精品试题(附讲解答案)
《C语言程序设计》精品试题一、单项选择题(答案P12)导读:单项选择题要求从给出的四个备选答案中,选出一个最符合题意的答案。本类习题主要检查对C语言基本概念的掌握情况,读者可根据学习进度选做部分习题。在完成习题的过程中,不但要选出正确的答案,而且要清楚不正确的选项错在何处,以加深对概念的理解。对于掌握不准的问题,应该通过上机实验来检验。【1.1】以下不正确的C语言标识符是____。A)intB)a_1_2C)ab1exeD)_x【1.2】以下是正确的C语言标识符是____。A)#defineB)_123C)%dD)n【1.3】下列四组字符串中都可以用作C语言程序标识符的一组是。A)printB)iamC)PxqD)str_l_3done_halfMy->bookCppoodbstart$itline#powaBc3paiHis.agewhile【1.4】下面各选项组中,均是C语言关键字的组是。A)auto,enum,includeB)switch,typedef,continueC)signed,union,scanfD)if,struct,type【1.5】下列不属于C语言关键字的是。A)defaultB)registerC)enumD)external【1.6】C语言程序从main()函数开始执行,所以这个函数要写在____。A)程序文件的开始B)程序文件的最后C)它所调用的函数的前面D)程序文件的任何位置【1.7】下列关于C语言的叙述错误的是____A)大写字母和小写字母的意义相同B)不同类型的变量可以在一个表达式中C)在赋值表达式中等号(=)左边的变量和右边的值可以是不同类型D)同一个运算符号在不同的场合可以有不同的含义140n【1.8】在C语言中,错误的int类型的常数是。A)32768B)0C)037D)0xAF【1.9】执行语句printf("%x",-1);屏幕显示____。A)-1B)1C)-ffffD)ffff【1.10】已知longi=32768;执行语句printf("%d",i);屏幕显示____。A)-1B)-32768C)1D)32768【1.11】已知longi=65539;执行语句printf("%d",i);屏幕显示____。A)65539B)-3C)3D)程序不能执行【1.12】在C语言中,整数-8在内存中的存储形式是。A)1111111111111000B)1000000000001000C)0000000000001000D)1111111111110111【1.13】C语言中字符型(char)数据在内存中的存储形式是____。 A)原码B)补码C)反码D)ASCII码【1.14】将字符g赋给字符变量c,正确的表达式是。A)c=147B)c="147"C)c='147'D)c='0147'【1.15】下列转义字符中错误的一个是____。A)' 00'B)' 014'C)'x111'D)'2'【1.16】将空格符赋给字符变量c,正确的赋值语句是____。A)c=' 'B)c=NULLC)c=0D)c=32【1.17】已知:chara='70';则变量a中。A)包含1个字符B)包含2个字符C)包含3个字符D)说明非法【1.18】字符串""EOFn=-61""的长度是____。A)8B)9C)14D)非法字符串【1.19】字符串""的长度是____。A)0B)1C)2D)非法字符串【1.20】已知:chara;intb;floatc;doubled;执行语句"c=a+b+c+d;"后,变量c的数据类型是。A)intB)charC)floatD)double【1.21】温度华氏和摄氏的关系是:C=-(F-32)。已知:floatC,F;由华氏求摄氏的正确的赋值表达式是____。A)C=5/9(F-32)B)C=5*(F-32)/9140nC)C=5/9*(F-32)D)三个表达式都正确【1.22】逗号表达式"(a=3*5,a*4),a+15"的值是____。A)15B)60C)30D)不确定【1.23】如果inta=1,b=2,c=3,d=4;则条件表达式"a5&&++x<10;A)1B)2C)3D)4【1.27】为判断字符变量c的值不是数字也不是字母时,应采用下述表达式____。A)c<=48||c>=57&&c<=65||c>=90&&c<=97||c>=122B)!(c<=48||c>=57&&c<=65||c>=90&&c<=97||c>=122)C)c>=48&&c<=57||c>=65&&c<=90||c>=97&&c<=122D)!(c>=48&&c<=57||c>=65&&c<=90||c>=97&&c<=122)【1.28】已知inta[3][2]={3,2,1};则表达式"a[0][0]/a[0][1]/a[0][2]"的值是____。A)0.166667B)1C)0D)错误的表达式【1.29】已知intx=1,y=1,z=1;表达式"x+++y+++z++"的值是____。A)3B)4C)5D)表达式错误【1.30】用十进制表示表达式"12|012"的值是____。A)1B)0C)12D)14【1.31】已知以下程序段:inta=3,b=4;a=a^b;b=b^a;a=a^b;则执行以上语句后a和b的值分别是____。A)a=3,b=4B)a=4,b=3C)a=4,b=4D)a=3,b=3【1.32】在位运算中,操作数每右移一位,其结果相当于____。A)操作数乘以2B)操作数除以2C)操作数除以16D)操作数乘以16140n【1.33】已知chara=222;执行语句a=a&052;后,变量a的值是____。A)222B)10C)244D)254【1.34】已知二进制数a是00101101,如果想通过整型变量b与a做异或运算,使变量a的高4位取反,低4位不变,则二进制数b的值应是____。A)11110000B)00001111C)11111111D)00000000【1.35】已知inta=15,执行语句a=a<<2以后,变量a的值是____。A)20B)40C)60D)80【1.36】已知intx=5,y=5,z=5;执行语句x%=y+z;后,x的值是____。A)0B)1C)5D)6【1.37】使用语句scanf("x=%f,y=%f",&x,&y);输入变量x、y的值(□代表空格),正确的输入是____。A)1.25,2.4B)1.25□2.4C)x=1.25,y=2.4D)x=1.25□y=2.4【1.38】下列循环语句中有语法错误的是____。A)while(x=y)5;B)while(0);C)do2;while(x==b);D)dox++while(x==10);【1.39】已知intx=(1,2,3,4);变量x的值是____。A)1B)2C)3D)4【1.40】表达式sizeof(double)是。A)函数调用B)double型表达式C)int型表达式D)非法表达式【1.41】执行语句printf("2:%d,",printf("1:%d,",scanf("%d",&x)));以后的输出结果是____。A)2:1,1:1,B)1:1,2:1,C)2:4,1:1D)1:1,2:4,【1.42】已知:intx,y;doublez;则以下语句中错误的函数调用是。A)scanf("%d,%lx,%le",&x,&y,&z);B)scanf("%2d*%d%lf",&x,&y,&z);C)scanf("%x%*d%o",&x,&y);D)scanf("%x%o%6.2f",&x,&y,&z);【1.43】与条件表达式"(n)?(c++):(c--)"中的表达式(n)等价的表达式是____。A)(n==0)B)(n==1)C)(n!=0)D)(n!=1)【1.44】已知inti=1,j=0;执行下面语句后j的值是____。while(i)switch(i){case1:i+=1;j++;break;case2:i+=2;j++;break;case3:i+=3;j++;break;default:i--;j++;break;}A)1B)2C)3D)死循环140n【1.45】求取满足式12+22+32+……+n2≤1000的n,正确的语句是____。A)for(i=1,s=0;(s=s+i*i)<=1000;n=i++);B)for(i=1,s=0;(s=s+i*i)<=1000;n=++i);C)for(i=1,s=0;(s=s+i*++i)<=1000;n=i);D)for(i=1,s=0;(s=s+i*i++)<=1000;n=i);【1.46】下面的for语句。for(x=0,y=10;(y>0)&&(x<4);x++,y--);A)是无限循环B)循环次数不定C)循环执行4次D)循环执行3次【1.47】已知inti=1;执行语句while(i++<4);后,变量i的值为____。A)3B)4C)5D)6【1.48】已知intx=12,y=3;执行下述程序后,变量x的值是____。do{x/=y--;}while(x>y);A)1B)2C)3D)程序运行有错误【1.49】已知chara[][20]={"Beijing","shanghai","tianjin","chongqing"};语句printf("%c",a[30]);的输出是____。A)<空格>B)nC)不定D)数组定义有误【1.50】若用数组名作为函数调用时的实参,则实际上传递给形参的是。A)数组首地址B)数组的第一个元素值C)数组中全部元素的值D)数组元素的个数【1.51】对二维数组的正确说明是____。A)inta[][]={1,2,3,4,5,6};B)inta[2][]={1,2,3,4,5,6};C)inta[][3]={1,2,3,4,5,6};D)inta[2,3]={1,2,3,4,5,6};【1.52】对字符数组s赋值,不合法的一个是____。A)chars[]="Beijing";B)chars[20]={"beijing"};C)chars[20];s="Beijing";D)chars[20]={'B','e','i','j','i','n','g'};【1.53】对字符数组str赋初值,str不能作为字符串使用的一个是____。A)charstr[]="shanghai";B)charstr[]={"shanghai"};C)charstr[9]={'s','h','a','n','g','h','a','i'};D)charstr[8]={'s','h','a','n','g','h','a','i'};【1.54】对函数形参的说明有错误的是____。A)inta(floatx[],intn)B)inta(float*x,intn)C)inta(floatx[10],intn)D)inta(floatx,intn)140n【1.55】如果一个变量在整个程序运行期间都存在,但是仅在说明它的函数内是可见的,这个变量的存储类型应该被说明为____。A)静态变量B)动态变量C)外部变量D)内部变量【1.56】在一个C源程序文件中,若要定义一个只允许在该源文件中所有函数使用的变量,则该变量需要使用的存储类别是。A)externB)registerC)autoD)static【1.57】在C语言中,函数的数据类型是指____。A)函数返回值的数据类型B)函数形参的数据类型C)调用该函数时的实参的数据类型D)任意指定的数据类型【1.58】已知如下定义的函数:fun1(a){printf("n%d",a);}则该函数的数据类型是____。A)与参数a的类型相同B)void型C)没有返回值D)无法确定【1.59】定义一个函数实现交换x和y的值,并将结果正确返回。能够实现此功能的是____。A)swapa(intx,inty)B)swapb(int*x,int*y){inttemp;{inttemp;temp=x;x=y;y=temp;temp=x;x=y;y=temp;}}C)swapc(int*x,int*y)D)swapd(int*x,int*y){inttemp;{int*temp;temp=*x;*x=*y;*y=temp;temp=x;x=y;y=temp;}}【1.60】求一个角的正弦函数值的平方。能够实现此功能的函数是____。A)sqofsina(x)floatx;{return(sin(x)*sin(x));}B)doublesqofsinb(x)floatx;{return(sin((double)x)*sin((double)x));}C)doublesqofsinc(x){return(((sin(x)*sin(x));}D)sqofsind(x)floatx;{return(double(sin(x)*sin(x)));140n【1.61】一个函数内有数据类型说明语句如下:doublex,y,z(10);关于此语句的解释,下面说法正确的是____。A)z是一个数组,它有10个元素。B)z是一个函数,小括号内的10是它的实参的值。C)z是一个变量,小括号内的10是它的初值。D)语句中有错误。【1.62】已知函数定义如下:floatfun1(intx,inty){floatz;z=(float)x/y;return(z);}主调函数中有inta=1,b=0;可以正确调用此函数的语句是____。A)printf("%f",fun1(a,b));B)printf("%f",fun1(&a,&b));C)printf("%f",fun1(*a,*b));D)调用时发生错误【1.63】下面函数的功能是____。a(s1,s2)chars1[],s2[];{while(s2++=s1++);}A)字符串比较B)字符串复制C)字符串连接D)字符串反向【1.64】在下列结论中,只有一个是错误的,它是。A)C语言允许函数的递归调用B)C语言中的continue语句,可以通过改变程序的结构而省略C)有些递归程序是不能用非递归算法实现的D)C语言中不允许在函数中再定义函数【1.65】已知:inta,*y=&a;则下列函数调用中错误的是。A)scanf("%d",&a);B)scanf("%d",y);C)printf("%d",a);D)printf("%d",y);【1.66】说明语句"int(*p)();"的含义是。A)p是一个指向一维数组的指针变量B)p是指针变量,指向一个整型数据C)p是一个指向函数的指针,该函数的返回值是一个整型D)以上都不对【1.67】设有说明int(*p)[4];其中的标识符p是。A)4个指向整型变量的指针变量140nB)指向4个整型变量的函数指针C)一个指向具有4个整型元素的一维数组的指针D)具有4个指向整型变量的指针元素的一维指针数组【1.68】已知:chars[10],*p=s,则在下列语句中,错误的语句是。A)p=s+5;B)s=p+s;C)s[2]=p[4];D)*p=s[0];【1.69】已知:chars[100];inti;则引用数组元素的错误的形式是。A)s[i+10]B)*(s+i)C)*(i+s)D)*((s++)+i)【1.70】已知:chars[6],*ps=s;则正确的赋值语句是。 A)s="12345";B)*s="12345";C)ps="12345";D)*ps="12345";【1.71】已知:chara[3][10]={"BeiJing","ShangHai","TianJin"},*pa=a;不能正确显示字符串"ShangHai"的语句是。A)printf("%s",a+1);B)printf("%s",*(a+1));C)printf("%s",*a+1);D)printf("%s",&a[1][0]);【1.72】已知:inta[4][3]={1,2,3,4,5,6,7,8,9,10,11,12};int(*ptr)[3]=a,*p=a[0];则以下能够正确表示数组元素a[1][2]的表达式是。A)*(*(a+1)+2)B)*(*(p+5))C)(*ptr+1)+2D)*((ptr+1)[2])【1.73】已知:inta[]={1,2,3,4,5,6,7,8,9,10,11,12},*p=a;则值为3的表达式是。A)p+=2,*(p++)B)p+=2,*++pC)p+=2,*p++D)p+=2,++*p【1.74】已知:inta[]={1,2,3,4},y,*p=a;则执行语句y=(*++p)--;之后,数组a各元素的值变为______。A)0,1,3,4B)1,1,3,4C)1,2,2,4D)1,2,3,3变量y的值是____。A)1B)2C)3D)4【1.75】已知:inta[]={1,3,5,7},y*p=a;为使变量y的值为3,下列语句正确的是____。A)y=++*p++;B)y=++(*p++);C)y=(++*p)++;D)y=(*++p)++;【1.76】已知:intx[]={1,3,5,7,9,11},*ptr=x;则能够正确引用数组元素的语句是。A)xB)*(ptr--)C)x[6]D)*(--ptr)【1.77】函数的功能是交换变量x和y中的值,且通过正确调用返回交换的结果。能正确执行此功能的函数是。A)funa(int*x,int*y)B)funb(intx,inty){int*p;{intt;p=x;*x=*y;*y=*p;t=x;x=y;y=t;}}C)func(int*x,int*y)D)func(int*x,int*y){*x=*y;*y=*x;{*x=*x+*y;*y=*x-*y;*x=*x-*y;140n}}【1.78】有定义如下:structsk{inta;floatb;}data,*p;如果p=&data;则对于结构变量data的成员a的正确引用是____。A)(*).data.aB)(*p).aC)p->data.aD)p.data.a【1.79】已知:structst{intn;structst*next;};staticstructsta[3]={1,&a[1],3,&a[2],5,&a[0]},*p;如果下述语句的显示是2,则对p的赋值是____。printf("%d",++(p->next->n));A)p=&a[0];B)p=&a[1];C)p=&a[2];D)p=&a[3];【1.80】已知:structperson{charname[10];intage;}class[10]={"LiMing",29,"ZhangHong",21,"WangFang",22};下述表达式中,值为72的一个是____。A)class[0]->age+class[1]->age+class[2]->ageB)class[1].name[5]C)person[1].name[5]D)clase->name[5]【1.81】已知:struct{inti;charc;floata;}test;则sizeof(test)的值是。A)4B)5C)6D)7【1.82】已知:union{inti;charc;floata;140n}test;则sizeof(test)的值是。A)4B)5C)6D)7【1.83】已知:unionu_type{inti;charch;floata;}temp;现在执行"temp.i=266;printf("%d",temp.ch)"的结果是。A)266B)256C)10D)1【1.84】若有以下程序段:structdent{intn;int*m;};inta=1,b=2,c=3;structdents[3]={{101,&a},{102,&b},{103,&c}};structdent*p=s;则以下表达式中值为2的是。A)(p++)->mB)*(p++)->mC)(*p).mD)*(++p)->m【1.85】若有以下说明语句,则对结构变量pup中sex域的正确引用是。structpupil{charname[20];intsex;}pup,*p;p=&pup;A)p.pup.sexB)p->pup.sexC)(*p).pup.sexD)(*p).sex【1.86】以下对结构变量stul中成员age的非法引用是。structstudent{intage;intnum;}stu1,*p;p=&stu1;A)stu1.ageB)student.ageC)p->ageD)(*p).age【1.87】若有以下定义和语句:uniondata{inti;charc;floatf;140n}a;intn;则以下语句正确的是。A)a=5;B)a={2,'a',1.2};C)printf("%dn",a);D)n=a;【1.88】已知:structsk{inta;intage;}date,*p;如果要使指针p指向data中的成员a,正确的赋值语句是____。A)p=(structsk*)&data.a;B)p=(structsk*)data.a;C)p=&data.a;D)*p=data.a;【1.89】已知enumweek{sun,mon,tue,wed,thu,fri,sat}day;则正确的赋值语句是____。A)sun=0;C)san=day;D)sun=mon;D)day=sun;【1.90】已知enumcolor{red,yellow=2,blue,white,black}ren;执行下述语句的输出结果是____。printf("%d",ren=white);A)0B)1C)3D)4【1.91】已知enumname{zhao=1,qian,sun,li}man;执行下述程序段后的输出是____。man=0;switch(man){case0:printf("Peoplen");case1:printf("Mann");case2:printf("Womann");default:printf("Errorn");}A)PeopleB)ManC)WomanD)Error【1.92】下述关于枚举类型名的定义中,正确的是____。A)enema={one,two,three};B)enema{one=9,two=-1,three};C)enema={"one","two","three"};D)enema{"one","two","three"};【1.93】C语言中标准输入文件stdin是指。 A)键盘B)显示器C)鼠标D)硬盘【1.94】要打开一个已存在的非空文件"file"用于修改,选择正确的语句____。A)fp=fopen("file","r");B)fp=fopen("file","a+");C)fp=fopen("file","w");D)fp=fopen('file","r+");140n【1.95】当顺利执行了文件关闭操作时,fclose函数的返回值是。A)-1B)TRUEC)0D)1【1.96】fscanf函数的正确调用形式是。A)fscanf(文件指针,格式字符串,输出列表);B)fscanf(格式字符串,输出列表,文件指针);C)fscanf(格式字符串,文件指针,输出列表);D)fscanf(文件指针,格式字符串,输入列表);【1.97】使用fgetc函数,则打开文件的方式必须是。A)只写B)追加C)读或读/写D)参考答案B和C都正确【1.98】已知宏定义#defineN3#defineY(n)((N+1)*n)执行语句z=2*(N+Y(5+1));后,变量z的值是____。A)42B)48C)52D)出错【1.99】已知宏定义#defineSQ(x)x*x,执行语句printf("%d",10/SQ(3));后的输出结果是____。A)1B)3C)9D)10【1.100】已知宏定义如下:#definePRprintf#defineNL"n"#defineD"%d"#defineD1DNL若程序中的语句是PR(D1,a);经预处理后展开为____。A)printf(%dn,a);B)printf("%dn",a);C)printf("%d""n",a);D)原语句错误【单项选择题参考答案】【1.1】答案:A注释:int是C语言的关键字【1.2】答案:B【1.3】答案:A【1.4】答案:B注释:include是预处理命令;scanf是函数名;type不是C语言的关键字。140n【1.5】答案:D【1.6】答案:D【1.7】答案:A【1.8】答案:A注释:int型表示整数的范围是-32768~32767。【1.9】答案:D注释:整型常量-1在计算机中表示为补码1111111111111111,用十六进制显示这个数时,最左边的1不会被解释为符号位,而是与右边其它位共同转换为十六进制数。【1.10】答案:B注释:长整型数32768在计算机内的表示是1000000000000000,以一般整型进行输出时,此数恰是-32768的补码。【1.11】答案:C注释:长整型数65539在计算机内的表示是00010000000000000011,以一般整型进行输出时,仅将右侧16位二进制数转换为十进制数。【1.12】答案:A注释:C语言中,int型的负数是采用补码表示的。【1.13】答案:D【1.14】答案:C注释:变量c是字符型,可用字符常量为它赋值。字符常量必须用单引号括起来,所以B是错误的;在单引号或双引号内的反斜线''用于表示转义字符,A选项在无引号时使用反斜线是错误的;C选项单引号内出现反斜线表示它与后面的数字组成一个转义字符;单引号只允许括起一个字符,D选项在单引号内出现4个字符,是错误的。【1.15】答案:C【1.16】答案:D注释:空字符和空格符是不同的两个字符,空格符的ASCII码值是32,空字符的ASCII值是0。【1.17】答案:A【1.18】答案:B【1.19】答案:A【1.20】答案:C【1.21】答案:B注释:单纯从C语言语法来说,选项B、C都是正确的,但是选项C中第一个运算的两个对象都是整型常数,其结果也是整型数0,最后的运算结果也就是0了。【1.22】答案:C【1.23】答案:A注释:将条件表达式增加一个括号,此式变为anext是a[0]的地址,引用其成员n再做前增1运算,结果就是2。【1.80】答案:B【1.81】答案:D【1.82】答案:A【1.83】答案:C注释:联合变量temp的成员是占用同一存储单元,它的长度是4个字节。266的二进制表示是100001010,存放在存储单元的低端两个字节,如下图:高字节00000001低字节00001010引用temp.ch进行输出,只取最低的第一个字节。【1.84】答案:D注释:由于结构指针指向了结构数组的0号元素,所以表达式(p++)->m的含义是先取出m(变量a的地址),然后指针p加1。表达式*(p++)->m的含义是先取出m的内容(变量a的值),然后指针p再加1。表达式(*p).m的含义是取出m(变量a的地址)。表达式*(++p)->m的含义是先将指针p加1,然后再取m的内容(变量b的值)。【1.85】答案:D【1.86】答案:B【1.87】答案:C【1.88】答案:A【1.89】答案:D【1.90】答案:D【1.91】答案:A【1.92】答案:B【1.93】答案:A【1.94】答案:D注释:函数fopen中的第二参数是打开模式,"r"模式是只读方式,不能写文件;"a+"模式是读/追加方式,允许从文件中读出数据,但所有写入的数据均自动加在文件的末尾;"w"模式是写方式,允许按照用户的要求将数据写入文件的指定位置,但打开文件后,首先要将文件的内容清空。"r+"模式是读/写方式,不但允许读文件,而且允许按照用户的要求将数据写入文件的指定位置,且在打开文件后,不会将文件的内容清空。本题的要求是"修改"文件的内容,因此只能选择答案D。【1.95】答案:C【1.96】答案:D【1.97】答案:C140n【1.98】答案:B注释:语句z=2*(N+Y(5+1)引用了两个宏定义。C语言是区分字母大小的,第二个宏定义中的N直接用3替换,用5+1替换n,则有z=2*(3+(3+1)*5+1);结果是48。注意对于带参数的宏亦是直接的文本替换,此例中n用5+1去替换,结果是(N+1)*5+1,而不是(N+1)*(5+1)。【1.99】答案:C注释:宏替换后的结果是printf("%d",10/3*3)。【1.100】答案:C二、阅读程序题(答案P35)导读:学会阅读程序对于初学者来说很重要,一方面可以巩固所学的语法知识,另一方面通过阅读别人写好的程序来打开自己的思路,就所谓见多识广。读者通过阅读理解程序,从给出的四个备选参考答案中,选择程序的正确输出。如果选择有误,就要认真分析原因,是概念方面的错误还是对程序逻辑理解不对,从而加深对语法规则的理解,提高程序设计能力。程序设计语言是开发程序的一个工具,学习语言的目的是为了编写程序来解决实际问题,所以特别提倡通过实际上机来检验备选答案,增强动手能力。习题基本上是按照教材的章节来安排的,读者可以根据学习的进度选择部分习题。【2.1】以下程序的输出结果是。main(){floata;a=1/100000000;printf("%g",a);}A)0.00000e+00B)0.0C)1.00000e-07D)0【2.2】下面程序的输出结果是____。#includechar*p="abcdefghijklmnopq";main(){inti=0;while(*p++!='e');printf("%cn",*p);}A)cB)dC)eD)f【2.50】下面程序的输出结果是____。#include 2)invent(①,n-2);else②;}【3.35】从键盘上输入10个整数,程序按降序完成从大到小的排序。#includeage,p->sex);②;}}data_out(structman*p,intn){structman*q=__③__;for(;p
name,p->age,p->sex);} 【3.46】输入N个整数,储存输入的数及对应的序号,并将输入的数按从小到大的顺序进行排列。要求:当两个整数相等时,整数的排列顺序由输入的先后次序决定。例如:输入的第3个整数为5,第7个整数也为5,则将先输入的整数5排在后输入的整数5的前面。程序如下:#include"stdio.h"#defineN10struct{intno;intnum;}array[N];main(){inti,j,num;for(i=0;i