在一个c语言源程序文件中所定义的全局变量,其作用域为,计算机二级C语言真题选择题...

计算机二级C语言真题选择题

{char t;int i,j;

for(i=0;i

for(j=i+1,j

if(s[0])>s[j][0]{t=s[0];s[0]=s[j][0];s[j][0]=t;}}

main()

{char ss[5][10]={“bcc”,”bbcc”,”xy”,”aaaacc””aabcc”}

fun(ss,5); printf(“%s,%s\n”,ss[0],ss[4]);}  程序运行结果是

A) xy,aaaacc B) aaaacc,xy    C) xcc,aabcc D) acc,xabcc

(40) 在一个C语言源程序文件中所定义的全局变量,其作用域为:

A) 所在文件的全部范围 B) 所在程序的全部范围

C) 所在函数的全部范围 D) 由具体定义位置和extern 说明来决定范围

(41)有以下程序

#include

int a=1;

int f(int c)

{static int a=2;

c=c+1;

return (a++)+c;}

main()

{ int i,k=0;

for(i=0;i<2;i++){int a=3;k+=f(a);}

k+=a;

printf(“%d\n”,k);}   程序运行结果是     A) 14   B) 15    C) 16    D) 17

(42)有以下程序

#include

void fun(int n,int *p)

{ int f1,f2;

if(n==1||n==2) *p=1;

else

{ fun(n-1,&f1); fun(n-2,&f2);

*p=f1+f2;}}

main()

{ int s;

fun(3,&s); printf("%d\n",s);}     程序的运行结果是     A)2   B)3   C)4      D)5

(43)若程序中有宏定义行:#define N 100 则以下叙述中正确的是

A)宏定义行中定义了标识符N的值为整数100    B)在编译程序对C源程序进行预处理时用100替换标识符N

C) 对C源程序进行编译时用100替换标识       D)在运行时用100替换标识符N

(44)以下关于typedef的叙述错误的是      A)用typedef可以增加新类型

B)typedef只是将已存在的类型用一个新的名字来代表C)用typedef可以为各种类型说明一个新名,但不能用来为变量说明一个新名           D)用typedef为类型说明一个新名,通常可以增加程序的可读性

(45)有以下程序

#include

struct tt

{int x;struct tt *y;} *p;

struct tt a[4]={20,a+1,15,a+2,30,a+3,17,a};

main()

{ int i;

p=a;

for(i=1;i<=2;i++) {printf("%d,",p->x); p=p->y;}}   程序的运行结果是  A)20,30, B)30,17 C)15,30, D)20,15,

(46)有以下程序

#include

#include

typedef struct{ char name[9];char sex; float score[2]; } STU;

STU f(STU a)

{ STU b={"Zhao",'m',85.0,90.0}; int i;

strcpy(a.name,b.name);

a. sex=b.sex;

for(i=0;i<2;i++) a.score=b.score;

return a;}

main()

{STU c={"Qian",'f',95.0,92.0},d;

d=f(c); printf("%s,%c,%2.0f,%2.0f\n",d.name,d.sex,d.score[0],d.score[1]);}  程序的运行结果是

A)Qian,f,95,92 B)Qian,m,85,90 C)Zhao,m,85,90 D)Zhao,f,95,92

(47)设有以下定义

union data

{ int d1; float d2; }demo;则下面叙述中错误的是

A)变量demo与成员d2所占的内存字节数相同     B)变量demo中各成员的地址相同

C)变量demo和各成员的地址相同           D)若给demo.d1赋99后, demo.d2中的值是99.0

(48)有以下程序

#include

main()

{ int a=1,b=2,c=3,x;

x=(a^b)&c; printf("%d\n",x);}     程序的运行结果是     A)0 B)1 C)2 D)3

(49)读取二进制文件的函数调用形式为:fread(buffer,size,count,fp); ,其中buffer代表的是

A)一个文件指针,指向待读取的文件        B)一个整型变量,代表待读取的数据的字节数

C)一个内存块的首地址,代表读入数据存放的地址      D)一个内存块的字节数

(50)有以下程序

#include

main()

{FILE *fp; int a[10]={1,2,3,0,0},i;

fp=fopen("d2.dat,"wb");

fwrite(a,sizeof(int),5,fp);

fwrite(a,sizeof(int),5,fp);

fclose(fp);

fp=fopen("d2.dat","rb");

fread(a,sizeof(int),10,fp);

fclose(fp);

for(i=0;i<10;i++) printf("%d",a);}    程序的运行结果是

A)1,2,3,0,0,0,0,0,0,0, B)1,2,3,1,2,3,0,0,0,0,  C)123,0,0,0,0,123,0,0,0,0, D)1,2,3,0,0,1,2,3,0,0,

【计算机二级C语言真题选择题】相关文章:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值