main()
{ int k, a[10]={1,2,3,4,5}
for(k=1k<3k++) fun(a)
for(k=0k<5k++) printf("%d", a[k])
}
A.34756
B.23445
C.35743
D.12345
(40) 请读程序:
#include
#define SUB(X,Y) (X)*Y
main()
{ int a=3, b=4
printf("%d", SUB(a++, b++))
}
上面程序的输出结果是
A.12
B.15
C.16
D.20(41) 请读程序:
#include
main()
{ int mun=0
while(num<=2)
{ num++printf("%d\n",num)}
}
上面程序的输出结果是
A.1
B.1
C.1
D.1
2 2 2
3 3
4
(42) 请读程序:
#include
main()
{ float x,y
scan("%f",&x)
if(x<0.0) y=0.0
else if((x<5.0)&&(x!=2.0))
y=1.0/(x+2.0)
else if (x<10.0) y=1.0/x
else y=10.0
printf("%f\n",y)
}
若运行时从键盘上输入2.0(表示回车),则上面程序的输出结果是
A.0.000000
B.0.250000
C.0.500000
D.1.000000
(43) 请读程序:
#include
main()
{ int x=1, y=0, a=0, b=0
switch(x)
{ case 1:
switch(y)
{ case 0: a++break
case 1: b++break
}
case 2:
a++b++break
}
printf("a=%d, b=%d\n",a,
B.
}
上面程序的输出结果是
A.a=2, b=1
B.a=1, b=1
C.a=1, b=0
D.a=2, b=2
(44) 若有下面的程序片段:
int a[12]={0}, *p[3], **pp, i
for(i=0i<3i++)
p[i]=&a[i*4]
pp=p
则对数组元素的错误引用是
A.pp[0][1]
B.a[10]
C.p[3][1]
D.*(*(p+2)+2)
(45) 请读程序:
#include
#include
main()
{ float x,y,z
scan("%f%f",&x,&y)
z=x/y
while(1)
{ if(fabs(z)>1.0)
{ x=yy=zz=x/y
}
else break
}
printf("%f\n",y)
}
若运行时从键盘上输入3.6 2.4(表示回车),则输出的结果是
A.1.500000
B.1.600000
C.2.000000
D.2.400000
(46) 请读程序:
#include
f(in b[], int n)
{ int i, r
r=1
for(i=0i<=ni++) r=r*b[i]
return r
}
main()
{ int x, a[]={ 2,3,4,5,6,7,8,9}
x=f(a, 3)
printf("%d\n",x)
}
上面程序的输出结果是
A.720
B.120
C.24
D.6
(47) 请读程序:
#include
#include
void fun( char *s)
{ char a[10]
strcpy( a, "STRING")
s=a
}
main()
{ char *p
fun(p)
x=f(a, 3)
printf("%s\n",p)
}
上面程序的输出结果是(└┘表示空格)
A.STRING└┘└┘└┘└┘
B.STRING
C.STRING└┘└┘└┘
D.不确定的值
(48) 若已建立下面的链表结构,指针p、s分别指向图中所示的结点,则不能将s所指的结点插入到链表末尾的语句组是
A.s->next=NULLp=p->nextp->next=s
B.p=p->nexts->next=p->nextp->next=s
C.p=p->nexts->next=pp->next=s
D.p=(*p).next(*s).next=(*p).next(*p).next=s
(49) 请读程序:
#include
void fun(float *pl, float *p2, float *s)
{ s=( float * )calloc( 1, sizeof(float))
*s=*p1+ *(p2++)
}
main()
{ float a[2]={1.1, 2.2}, b[2]={10.0, 20.0}, *s=a
fun(a, b, s)
printf("%f\n",*s)
}
上面程序的输出结果是
A.11.100000
B.12.100000
C.21.100000
D.1.100000
(50) 请读程序:
#include
#include
void fun( char *w, int m)
{ char s, *p1, *p2
p1=wp2=w+m-1
while (p1{ s=*p1++*p1=*p2--*p2=s}
}
main()
{ char a[]="ABCDEFG"
fun( a, strlen(a))
puts(a)
}
上面程序的输出结果是
A.GFEDCBA
B.AGADAGA
C.AGAAGAG
D.GAGGAGA
二、填空题(每空2分,共40分)
请将每空的正确答案写在答题卡上【1】-【20】序号后的横线上,答在试卷上不得分。
(1) DOS命令分为内部命令与外部命令,XCOPY命令是 【1】 命令
(2) 为了列出当前盘当前目录中所有第三个字符为C的文件名的有关信息,应该用命令 【2】 。
(3) 设当前盘为A盘,当前目录为\X\Y,A盘上的一个文件QR.C在当前目录下的子目录W中。现已将A盘的当前目录改为\D\XY,当前盘改为C盘,如需指定A盘上该文件应写成 【3】 。
(4) 用十六进制给存储器中的字节地址进行编号,其地址编号是从0000到FFFF,则该存储器的容量是【4】KB。
(5) 设有两个八位二进制数00010101与01000111相加,其结果的十进制表示为 【5】 。
(6) 数学式子 写成C语言表达式是 【6】 。
(7) 下面程序的输出结果是 【7】 。
#include
main()
{ static char b[]="Goodbye"
char *chp=&b[7]
while( --chp >=&b[0]) putchar( *chp)
putchar(’\n’)
}
(8) 下面程序的输出结果是 【8】 。
#include
void as( int x, int y, int *cp, int *dp)
{ *cp=x+y
*dp=x-y
}
main()
{ int a=4, b=3, c, d
as( a, b, &c, &d)
printf( ’%d %d\n", c, d)
}
(9) 请读程序:
#include
main( int argc, char *argv[])
{ int i
printf( ’%d\n", argc)
for( i=0i<=argc+1i++) printf( "%s ", argv[i])
printf("\n")
}
若上面的程序编译、连接后生成可执行文件ABC.EXE,则输入以下命令行
abc file1 file2(表示回车)
程序执行后的输出结果是 【9】 。
(10) 条件“20(11) 设二进制数a是00101101,若想通过异或运算a^b使a的高4位取反,低4位不变,则二进制数b应是 【11】 。
(12) 若有以下说明和定义语句,则变量w在内存中所占的字节数是 【12】 。
union aa
{ float x, y
char c[6]
}
struct st { union aa vfloat w[5]double ave} w
(13) 下面程序的输出结果是 【13】 。
#include
#define N 5
fun( char *s, char a, int n)
{ int j
*s=aj=n
while( ereturn j
}
main()
{ char s[N+1]
int k, p
for( k=1k<=Nk++)
s[k]=’A’+k+1
printf( "%d\n", fun(s, ’E’, N))
}(14) 下面程序的输出结果是 【14】 。
#include
void fun( char *a1, char *a2, int n)
{ int k
for( k=0ka2[k]=( a1[k]-’A’-3+26)&+’A’
a2[n]=’\0’
}
main()
{ char s1[5]="ABCD", s2[5]
fun( s1, s2, 4)
puts( s2)
}
(15) 下面的findmax函数返回数组s中最大元素的下标,数组中元素的个数由t传入,请填空。
findmax( int s[], int t)
{ int k, p
for( p=0, k=ppif( s[p]>s[k]) 【15】 。
return k
}
(16) 下面程序的输出结果是 【16】 。
#include
fun( int x)
{ int p
if( x==0||x==1) return(3)
p=x-fun( x-2)
return p
}
main()
{ printf( "%d\n", fun(9))}
(17) 下面程序的输出结果是 【17】 。
#include
funa( int a, int b)
{ return a+b}
funb( int a, int b)
{ return a-b}
sub( int (*t)(), int x, int y)
{ return((*t)( x,y))}
main()
{ int x, (*p)()
p=funa
x=sub(p,9,3)
x+=sub(funb, 8, 3)
printf("%d\n", x)
}
(18) 下面程序的输出结果是 【18】 。
#include
main()
{ char *p[]={ "BOOL", "OPK", "H", "SP"}
int i
for(i=3i>=0i--,i--) printf( "%c", *p[i])
printf("\n")
}
(19) 为了建立如图所示的存储结构(即每个结点含两个域,data是数据域,next是向结点的指针域),请填空。
data next
struct link { char data【19】 } node
(20) 下面的程序用来统计文件中字符的个数,请填空。
#include
main()
{ FILE *fp
long num=0
if(( fp=fopen("fname.dat","r"))==NULL)
{ printf( "Can’t open file! \n")exit(0)}
while 【20】
{ fgetc(fp)num++}
printf("num=%d\n", num)
fclose(fp)
}
参考答案一`选择题((1)~(40)题每题1分,(41)~(50)题每题2分,共60分)
(1)C (2)A (3)B (4)D (5)D (6)A (7)C (8)B (9)D (10)C
(11)B (12)D (13)A (14)C (15)B (16)A (17)B (18)A (19)C (20)C
(21)D (22)B (23)B (24)A (25)C (26)D (27)D (28)B (29)C (30)A
(31)B (32)B (33)D (34)C (35)A (36)C (37)A (38)B (39)C (40)A
(41)C (42)C (43)A (44)C (45)B (46)B (47)D (48)C (49)D (50)C
二` 填空题(每空2分,共40分)
(第(2)`(3)空允许小写或大小写混合使用,其它空均须与答案一样)
(1) 外部
(2) DIR ?? C*.*
(3) A:\X\Y\W\QR.C
(4) 64
(5) 92
(6) pow(sin(x),2) * (a+b)/(a-b) 或 sit(x) * sit(x) * (a+b)/(a-b)
(7) eybdooG
(8) 7 1
(9) 3 abc.exe file1 file2 (注:两个答案,每个1分)
(10) ((20 (11) 11110000
(12) 34
(13) 3
(14) XYZA
(15) k=p
(16) 7
(17) 17
(18) SO
(19) struct link *next
(20) (!feof(fp))或(feof(fp)==0)
c语言程序设计试题
阐述编程语言的概念,学习进制转换以及程序的基本运行原理,让大家先有一个整体上的认识。下面是我整理的关于c语言程序设计基础知识,希望大家认真阅读!
【程序1】
题目:有1、2、3、4个数字,能组成多少个互不相同且无重复数字的三位数?都是多少?
1.程序分析:可填在百位、十位、个位的数字都是1、2、3、4。组成所有的排列后再去
掉不满足条件的排列。
2.程序源代码:
代码如下:
#include "stdio.h"
#include "conio.h"
main()
{
int i,j,k
printf("\n")
for(i=1i<5i++) /*以下为三重循环*/
for(j=1j<5j++)
for (k=1k<5k++)
{
if (i!=k&&i!=j&&j!=k) /*确保i、j、k三位互不相同*/
printf("%d,%d,%d\n",i,j,k)
}
getch()
}
【程序2】
题目:企业发放的奖金根据利润提成。利润(I)低于或等于10万元时,奖金可提10%利润高
于10万元,低于20万元时,低于10万元的部分按10%提成,高于10万元的部分,可可提
成7.5%20万到40万之间时,高于20万元的部分,可提成5%40万到60万之间时高于
40万元的部分,可提成3%60万到100万之间时,高于60万元的部分,可提成1.5%,高于
100万元时,超过100万元的部分按1%提成,从键盘输入当月利润I,求应发放奖金总数?
1.程序分析:请利用数轴来分界,定位。注意定义时需把奖金定义成长整型。
2.程序源代码:
代码如下:
#include "stdio.h"
#include "conio.h"
main()
{
long int i
int bonus1,bonus2,bonus4,bonus6,bonus10,bonus
scanf("%ld",&i)
bonus1=100000*0. 1
bonus2=bonus1+100000*0.75
bonus4=bonus2+200000*0.5
bonus6=bonus4+200000*0.3
bonus10=bonus6+400000*0.15
if(i<=100000)
bonus=i*0.1
else if(i<=200000)
bonus=bonus1+(i-100000)*0.075
else if(i<=400000)
bonus=bonus2+(i-200000)*0.05
else if(i<=600000)
bonus=bonus4+(i-400000)*0.03
else if(i<=1000000)
bonus=bonus6+(i-600000)*0.015
else
bonus=bonus10+(i-1000000)*0.01
printf("bonus=%d",bonus)
getch()
}
【程序3】
题目:一个整数,它加上100后是一个完全平方数,再加上168又是一个完全平方数,请问该数是多少?
1.程序分析:在10万以内判断,先将该数加上100后再开方,再将该数加上268后再开方,如果开方后
的结果满足如下条件,即是结果。请看具体分析:
2.程序源代码:
代码如下:
#include "math.h"
#include "stdio.h"
#include "conio.h"
main()
{
long int i,x,y,z
for (i=1i<100000i++)
{
x=sqrt(i+100)/*x为加上100后开方后的结果*/
y=sqrt(i+268)/*y为再加上168后开方后的结果*/
if(x*x==i+100&&y*y==i+268) /*如果一个数的平方根的平方等于该数,这说明此数是完全平方数*/
printf("\n%ld\n",i)
}
getch()
}
【程序4】
题目:输入某年某月某日,判断这一天是这一年的第几天?
1.程序分析:以3月5日为例,应该先把前两个月的加起来,然后再加上5天即本年的.第几天,特殊
情况,闰年且输入月份大于3时需考虑多加一天。
2.程序源代码:
代码如下:
#include "stdio.h"
#include "conio.h"
main()
{
int day,month,year,sum,leap
printf("\nplease input year,month,day\n")
scanf("%d,%d,%d",&year,&month,&day)
switch(month) /*先计算某月以前月份的总天数*/
{
case 1:sum=0break
case 2:sum=31break
case 3:sum=59break
case 4:sum=90break
case 5:sum=120break
case 6:sum=151break
case 7:sum=181break
case 8:sum=212break
case 9:sum=243break
case 10:sum=273break
case 11:sum=304break
case 12:sum=334break
default:printf("data error")break
}
sum=sum+day/*再加上某天的天数*/
if(year%400==0||(year%4==0&&year%100!=0)) /*判断是不是闰年*/
leap=1
else
leap=0
if(leap==1&&month>2) /*如果是闰年且月份大于2,总天数应该加一天*/
sum++
printf("It is the %dth day.",sum)
getch()
}
【程序5】
题目:输入三个整数x,y,z,请把这三个数由小到大输出。
1.程序分析:我们想办法把最小的数放到x上,先将x与y进行比较,如果x>y则将x与y的值进行交换,
然后再用x与z进行比较,如果x>z则将x与z的值进行交换,这样能使x最小。
2.程序源代码:
代码如下:
#include "stdio.h"
#include "conio.h"
main()
{
int x,y,z,t
scanf("%d%d%d",&x,&y,&z)
if (x>y)
{t=xx=yy=t} /*交换x,y的值*/
if(x>z)
{t=zz=xx=t} /*交换x,z的值*/
if(y>z)
{t=yy=zz=t} /*交换z,y的值*/
printf("small to big: %d %d %d\n",x,y,z)
getch()
}
【程序6】
题目:用*号输出字母C的图案。
1.程序分析:可先用'*'号在纸上写出字母C,再分行输出。
2.程序源代码:
代码如下:
#include "stdio.h"
#include "conio.h"
main()
{
printf("Hello C-world!\n")
printf(" ****\n")
printf(" *\n")
printf(" * \n")
printf(" ****\n")
getch()
}
【程序7】
题目:输出特殊图案,请在c环境中运行,看一看,Very Beautiful!
1.程序分析:字符共有256个。不同字符,图形不一样。
2.程序源代码:
代码如下:
#include "stdio.h"
#include "conio.h"
main()
{
char a=176,b=219
printf("%c%c%c%c%c\n",b,a,a,a,b)
printf("%c%c%c%c%c\n",a,b,a,b,a)
printf("%c%c%c%c%c\n",a,a,b,a,a)
printf("%c%c%c%c%c\n",a,b,a,b,a)
printf("%c%c%c%c%c\n",b,a,a,a,b)
getch()
}
【程序8】
题目:输出9*9口诀。
1.程序分析:分行与列考虑,共9行9列,i控制行,j控制列。
2.程序源代码:
代码如下:
#include "stdio.h"
#include "conio.h"
main()
{
int i,j,result
printf("\n")
for (i=1i<10i++)
{
for(j=1j<10j++)
{
result=i*j
printf("%d*%d=%-3d",i,j,result)/*-3d表示左对齐,占3位*/
}
printf("\n")/*每一行后换行*/
}
getch()
}
【程序9】
题目:要求输出国际象棋棋盘。
1.程序分析:用i控制行,j来控制列,根据i+j的和的变化来控制输出黑方格,还是白方格。
2.程序源代码:
代码如下:
#include "stdio.h"
#include "conio.h"
main()
{
int i,j
for(i=0i<8i++)
{
for(j=0j<8j++)
if((i+j)%2==0)
printf("%c%c",219,219)
else
printf(" ")
printf("\n")
}
getch()
}
c语言考试题(一)
一、 单项选择题(每题2分,共20分)
1、以下选项中属于C语言的数据类型是( )
A.复数型 B.逻辑型 C.集合型 D.双精度型
2、一个C程序的执行是从( )
A.main()函数开始,直到main()函数结束 B.第一个函数开始,直到最后一个函数结束
C.第一个语句开始,直到最后一个语句结束 D.main()函数开始,直到最后一个函数结束
3、设有语句int a=3则执行语句a+=a-=a*a;后,变量a的值是( )
A.3 B.0C.-12 D.9
4、若有 char c[5]={'c','d','\0','e','\0'}则执行语句printf("%s",c)结果是( )。
A.cd\0e B.'c''d' C.cd D.cd e
5、已知:int a[2][3]={1,2,3,4,5,6}, (*p)[3]=a则下列表达式不是4的是 ( )。
A.*(*p+3) B.*p+3 C.*(*(p+0)+3) D.a[0][3]
6、以下有宏替换不正确的叙述( ).
A.宏替换不占用运行时间 B.宏名无类型
C.宏替换只是字符串替换 D.宏名必须用大写字母表示
7、执行char str[10]=”Ch\nina”strlen(str)的值是( )
A.5 B.6 C.7 D.9
8、下面程序的输出结果是:( )
#define POWER(x) (x*x)
main()
{int i=4printf("%d",POWER(i-2))}
A. -9 B. -7 C. 5 D. -6
9、在定义int a[3][4][2]后,第10个元素是( )
A.a[2][1][2] B.a[1][0][1] C.a[2][0][1] D.a[2][2][1]
10、下面程序的输出结果是:( )
typedef struct
{long x[2]<br>short y[4]<br>char z[8]<br>}MYTYPE
MYTYPE a
main()
{ printf("%d\n",sizeof(a))}
A. 2 B. 8 C. 14 D. 24
二、 填空题(每空1分,共11分)
1、字符串"A"在内存中占用的字节数为 。
2、C语言中的标识符只能由字母、下划线和 组成。
3、若有定义语句“ int a=25,b=14,c=19",以下语句的执行结果是
if(a++<=25&&b--<=2&&c++) printf("***a=%d,b=%d,c=%d\n",a,b,c)
else printf("###a=%d,b=%d,c=%d\n",a,b,c)
4、有如下定义a[]="B\172\\\'a%%"则执行语句printf("%d",strlen(a))的结果为 。
5、若有定义:int a[12]={1,2,3,4,5,6,7,8,9,10,11,12},*p[4],ifor(i=0i<4i++) p[i]=&a[i*3]则*(*(p+1)+2)的值为 ,*p[2]的值为 。若数组的首地址为2000,则p[1]指向的地址为 。
6、设a=2,b=3,x=3.5,y=2.5,则表达式(float)(a+b)/2+(int)x%(int)y 的结果是 。
7、设x、y都是int型变量,初值都为1,则执行表达式:--x&&y++后,y的值为 。
8、语句for(i=1i==10i++)continue循环的次数是 。
9、以下程序输出 。
main()
{enum em {em1=3,em2=1,em3}
char *aa[]={"AA","BB","CC","DD"}printf("%s%s%s\n",aa[em1],aa[em2],aa[em3])
}
三、 写程序结果(每题5分,共35分)
1、#include
main()
{int x,y,z<br>x=1,y=2,z=3x+=y+=z<br>printf("1:%d\n",z+=x>y?x++:y++)<br>x=0x02ffy=0xff00<br>printf("2:%d\n",(x&y)>>4|0x005f)<br>x=y=z=-1++x||++y&&++z<br>printf("3:%d,%d,%d\n",x,y,z)<br>}
2、#define f(x) x*x
main()
{int a=6,b=2,c<br>c=f(a+b)/f(b)<br>printf(“%d\n”,c)<br>}
3、fun(int k)
{ printf("%d",k);
if(k>0)
fun(k-1);
}
main( )
{ int w=5; fun(w); printf("\n")}
4、#include
main()
{int x=1,y=0<br>switch(x)<br>{ case 1:<br>switch(y)<br>{ case 0:printf(“first\n”)break<br>case 1:printf(“second\n”)break<br>}
case 2:printf(“third\n”)
}
}
5、#include
main()
{ int k=4
func(k)func(k)
}
func(int a)
{ static int m=0
m+=a
printf("%d",m)
}
6、struct st
{ int x
int *y
}*p
int s[]={30,20}
struct st a[]={1,&s[0],2,&s[1]}
main()
{ p=aprintf("%d,",p->x)
printf("%d\n",++(*(++p)->y))
}
7、假定在当前盘目录下有2个文本文件,其名称和内容如下:
文件名: a1.txt a2.txt
内容: ABCDEF# abcdef#
#include "stdio.h"
main()
{FILE *fp<br>void fc()<br>if((fp=fopen("a1.txt","r"))==NULL)<br>{printf("Can not open file!\n")exit(1)}
else{fc(fp)fclose(fp)}
if((fp=fopen("a2.txt","r"))==NULL)
{printf("Can not open file!\n")exit(1)}
else{fc(fp)fclose(fp)}
}
void fc(fp1)
FILE *fp1
{char c<br>while((c=fgetc(fp1))!='#')putchar(c)<br>}
四、 程序填空(每空2分,共14分)
1、下面程序求矩阵a的主对角线元素之和,请填空。
main()
{ int a[3][3]={2,4,6,8,10,12,14,16,18}
int sum=0,i,j
for(i=0i<3① )
for(j=0② j++)
if(i= =j) sum=sum+ ③
printf("sum=%d\n",sum)
}
2、下列函数coy把字符数组S2中的全部字符复制到字符数组S1中, 复制时’\0’也要复制过去,’\0’后面的字符不用。
coy(char s1[],char s2[])
{ int i
for(i=0s2[i]!= ① i++)
s1[i]=s2[i]
②
}
3、下面程序的功能是将字符串a中的下标为奇数的元素由小到大排序,其他元素不变,请填空。
main()
{ char a[]="students",tint i,j
for(i=1i<7i+=2)
for(j=i+2j<8① )
if( ② )
{t=a[i]a[i]=a[j]a[j]=t}
puts(a)
}
c语言考试题(二)
一. 填空题(每题2分,共20分)
1. C语言基本数据类型有:_______________________________;
构造类型有:_____________________________________。 P.13
2. C语言源程序注注释符号是:________________________________,
为表明层次结构,C语言源程序通常采用_____________________格式编写。P.4
3. 源程序TEST.C经编译产生的目标文件是:________________________;
经连接处理后,产生的可执行文件是:__________________________。
4. strlen(“1234 \ 0xy)的值为:_____________________________;
sizeof(float)的值为:____________________________
5. 二维数组a[10] [50]最后一行的首地址为:_________________________;
最后一个元素的首地址为:____________________________________。
6. C标准库函数中,数学函数的原型在:________________头文件中,自定义头文件D :\ MYC \ MY . H应如何包含到源程序文件中:_________________________。P.130
7. 已知函数定义为:int stat(int a,float *p)
{……………}
则此函数的两个参数类型分别是_______________ 、 _____________________。
8. 设int x,y,z=4;
x=y=++z;
x=(y>z)?x+2;x++;则x的值是:_________;
设int a=0,b=0,c=0;c=++a | | b++; ,则a、b、c值分别是:_____________。
9. 与if (x=0) 等价的写法是if ( ! x );
判断两个(float)变量x,z是否相等一般:if ( fabc(x-z)<1e-6 )。
10.已知赋值语句zhang.year=1985;可判断zhang是_______________类型的变量;
定义文件指针的C语句是:_________________________________。
二. 单项选择题 (每题1分,共10分)
1. 组成C程序的基本单位是____________________________。
A.函数 B.标识符 C.表达式 D.语句
2. 设int类型的数据长度为2字节,则该类型数据的取值范围是__________________。
A.0至65536 B.0至65535
C.-32767至32768 D.-32768至32767
3. 在C语言中,逻辑值“真”是用_____________________表示的。
A.预定义为真值的宏 B.非零数
C.正数 D.非零整数
4. C语言对于嵌套if语句规定else总是与_____________________匹配。
A.与最外层的if B.与之前最近的if
C.与之前最近的不带else的if D.与最近的{ }之前的if
5. 数组定义char a[10]={`a`,`b`,`c`}:包括了几个元素____________________。
A.3 B.9 C.4 D.10
6. 数组名作为实参传给被调用的函数时,形参获得的是_____________________。
A.该数组第一个元素的值 B.该数组所有元素的值
C.该数组第一个元素的首地址 D.该数组所有元素的首地址
7. 为表示关系x ≥ y ≥z,正确的C语言表达式为_________________________。
A.(x>=>y>=z) B.(x>=y)AND(y>=z)
C.(x>=y)&&(y>=z) D.(x>y)&(y>=z)
8. 根据定义int a[ ]={1,2,3},i,*p=a; 从语法分析_________________是不正确的。
A. a[p-a] B.*(&a) C.p D.*(*(a+i))
9. 若有语句scanf(“%d%d”,&a,&b);要使变量a,b分别得到12和34;正确的输入形式为____________________________。
A.12 34 B.12,34 C.1234 D.12:34
10.union uex {int i;float f;char c;}ex;则sizeof(ex)的值是____________________。
A.4 B.5 C.6 D.7
三. 分析程序,写出运行结果。(每题4分,共20分)
1. 源程序如下,运行时假定键盘输入字符串为``2004``
#include
void main(void)
{
int n=0
char c
while( (c=getchar( )) ! =`\n` ) /*字符型数字*/
{
if (c>=`0`&&c<=`9` )
n = n*10 + c- `0` /*数字*/
}
printf(“value=%d|n” ,n)
}
结果为: value=2004 。
2. 源程序如下:
#include
void main(void)
{
int num[9]={399,398,397,396,395,299,290,311,301};
int score[9]={81,85,59,77,90,66,89,93,73};
int iMax,iPos,i;
iPos=0;
iMax=score[iPos];
for(i=1;i<9;i++)
if(score>iMax)
{
iPos=i;
iMax=score[iPox];
}
printf(“num=%d,score=%d”,num[iPos];score[iPos]);
结果为: num=311, score=93 。
3. 源程序如下,运行时假定键盘输入数据为:1 2 3 4 5 6 7 8 9 10
#include
void main(void)
{
int i,a[10];
int *p;
p=a;
for(i=0;i<10;i++)
scanf(“%d“,p++);
for(p=a;p<SPAN>;p++)
if (*p%2)printf(“%3d”,*p)
}
结果为: 1 3 5 7 9 。
4. 源程序如下,两次运行,分别输入数据13和21
#include
#include
void main(void)
{
int n,s;
scant (“%d”,&n);
s=panduan( n);
if(s==1)printf(“yes\n”);
else printf(“no\n);
}
int panduan(int n)
{
int k,j;
k=(int)sqrt((double)n);
for(j=2;j<=k,j++)
{
if(n%j==0) break;
}
if(j>k) retum(1);
else retum(0);
}
结果为 yes
no
5.源程序如下,运行时假定键盘输入字符为:AxByCz
#include
#include
void main(void)
{
char str[80];
int i;
gets(str);
for(i=0;str!=`\0`;i++)
if(str>=`a`&&str<=`z`) str-=32;
else if (str>=`A`&&str<=`Z`) str+=32;
puts(str);
}
结果为: aXbYcZ 。
四. 下列程序中每个划线处有一个错误,改正划线 中的错误,使其实现题目要求。(每体4分,共20分)
1. 求 s=1+2+3+、、、、、、、+100
include 改正为_________________________。
void sum (void) 改正为_________________________。
{
int s,i;
for (s=0,i=1;i<=100;i++)
{
s=s+ i ++; 改正为__________________________。
}
printf (“s=%f”,s) 改正为__________________________。
}
2. 源程序实现求x
#include
double pow(float . int) 改正为_________________________。
void main(void)
{
int i, n
float x
scanf (“%f,%d”,&x,&n)
for (i=1i<9i++)
printf(“%d,%e\n”, i, pow(i,x)
} 改正为______________________。
double v v pow(float x, int n)
{
int i
double p=0改正为______________________。
for (i=1i<i++)>改正为_______________________。
p*=x
retum(p)
}
3. 源程序实现排升序。
#include
void main(void)
{
int i, j, iMin, a[10]={4,3,5,1,10,12,2,6,7,9}, iTemp
for (i=0i<9i++)
{
iMin=0改正为_______________________。
for (j=i+1j<10j++)
if(a[iMin]<iMin="j">改正为_______________________。
if (iMin==i) 改正为_________________________。
{ iTemp=a
a[iMin]=a改正为_________________________。
a[iMin]=iTemp
}
}
for(i=0i<10i++)
printf(“%4d”, a):
}
4. 源程序为求平均值。
#include
void main(void)
{
int i, sum改正为____________________。
float avg
int sc[10], *p=sc
for (i=0, i<10i++) 改正为____________________。
{
scanf(“%d”, p++)
sum+= *p改正为____________________。
}
avg = sum/ 10改正为___________________。
printf(“avg=%f”, avg)
}
5. 源程序求 eX=1+x+x2/2!+……+xn/n!前n+1项之和
#include
void main(void>
{
float exp , x , t
int i, n
scanf(“%f, %d”,&x, &n)
t=0改正为___________________。
exp=1.0
for(i=1 i<=ni++)
{
if(t<1e-6) loop改正为__________________。
t+=x/i改正为___________________。
exp*=t改正为___________________。
}
printf(“\n%15.6f”, exp)
}
五. 编程题 (每题6分,共30分)
1. 根据以下程序框架,编写子函数,实现交换两个整型变量x和y的值。
#include
void swap (int *, int *)
void main (void)
{
int x, y
scanf(“%d, %d”, &x, &y)
swap( &x, &y)
printf(“%d, %d”, x, y)
}
void swap( )
{
}
2. 设某班人数36人,参加C语言考试,用一维数组score[36]存放考试成绩,已给出一部分程序,完善以下程序,使其实现统计并输出不及格人数及百分比。
#include
void main (void)
{ int i
float scoer[36], precent
int count=0
for (i=0i<36i++)
{
scanf(“%f”, &score)
}
3. 完善以下程序使其实现由键盘任意输入一串字符,统计其中大写字母个数iA、小写字母个数ia、其他字符个数iother。
#include
#include
void main (void)
{
char str [80]
int i, iA=0, ia=0, iother=0
}
4. 完善以下程序使其实现求方阵主和辅对角线元素之和及其转置矩阵,设方阵用二维数组a表示,转置矩阵用t表示,sl和s2表示主和辅对角线元素之和。
#include
void main(void)
{
int a[3] [3]={1,3,5,7,9,11,13,15,11}
int i, j, s1, s2
int t[3] [3]
printf(“%d, %d,\n”,s1, s2)
for(i=0i<3i++)
for(j=0j<3j++)
printf(“%3d”, t [j])
}
5. 已知字符数组str[80],编写返回指针的子函数,实现在其中查找字符ch首次出现的位置。
#include
#include
#include
char *lstrchar(char*, char)
void main(void)
{
char c, *p, str[80]
gets (str)
scanf(“%c”, &c)
p=lstrchar(str,c)
if(p==NULL) printf(“char %c not found\n”c)
else printf(“The position is %d”, p-str)
char “lstrchar( )
{ }
历年全国计算机二级考试c语言真题及答案
http://jsj.lsxy.com/UploadFiles/20064222324839.rar
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)