当前位置:文档之家› 省二级选择题题库C语言.

省二级选择题题库C语言.

省二级选择题题库C语言.
省二级选择题题库C语言.

51001.以下数组定义中,正确的是()。A

A)int a[5]={0};

B)int a[]={0 1 2};

C)int a[5]=0;

D)int a[];

51002.下列数组定义中,正确的是().A

A)int a[10];

B)int n=10,a[n];

C)int N=10;int a[N];

D)int n;scanf("%d",&n); int a[n]; 51003.已知int a[10];则对a数组元素引用不正确的是().A

A)a[10]

B)a[3+5]

C)a[10-10]

D)a[5]

51004.若有定义:int a[3]={0,1,2};则a[1]的值为()。B

A)0

B) 1

C) 2

D) 3

51005.若有定义:int a[5]={1,2,3,4,5};则语句a[1]=a[3]+a[2+2]-a[3-1];运行后a[1]的值为()。A

A) 6

B) 5

C) 1

D) 2

51006.以下能对一维数组a进行正确初始化的语句是()。D

A)int a[5]=(0,0,0,0,0);

B)int a[5]=[0];

C)int a[5]={1,2,3,4,5,6,7};

D)int a[]={0};

51007.下面程序段的运行结果是()。D

int i=0,a[]={3,4,5,4,3};

do{

a[i]++;

}while(a[++i]<5);

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

printf("%d ",a[i]);

A) 4 5 6 5 4

B) 3 4 5 4 3 C) 4 5 5 5 4

D) 4 5 5 4 3

51008.下面程序段的运行结果是()。C

int i=0,a[]={7,5,7,3,8,3};

do{

a[i]+=2;

}while(a[++i]>5);

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

printf("%d ",a[i]);

A)9 7 9 5 10 5

B)9 5 9 3 10 3

C)9 5 7 3 8 3

D)7 5 7 3 8 3

51009.下面程序段的运行结果是()。A

int i=0,a[]={1,2,3,4,5};

do{

a[i]+=10;

}while(a[++i]>2);

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

printf(“%d”,a[i]);

A)11 2 3 4 5

B) 1 2 3 4 5

C)11 12 13 14 15

D)11 12 3 4 5

51101.设有如下程序段:

int a[3][3]={1,0,2,1,0,2,1,0,1},i,j,s=0;

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

for(j=0;j

s=s+a[i][j];

则执行该程序段后,s的值是()。C

A)0

B) 1

C) 2

D) 3

51102.有如下定义:int a[][3]={1,2,3,4,5,6,7,8};则数组a的行数是().B

A) 2

B) 3

C) 4

D)无法确定的

51103.以下数组定义中,正确的是()。D

A)int a[2][3]={1,2,3,4,5,6,7};

B)int a[][]={{1,2,3},{4,5,6},{7,8,9}};

C)int a[2][]= {1,2,3,4,5,6};

D)int a[][4]= {6};

51104.若有定义:int a[3][4]={{1,2},{0},{1,2,3}};则a[1][1]的值为()。A

A)0

B){1,2}

C) 1

D) 3

51105.若有定义:int a[3][3];则表达式&a[2][1]-a的值是().A

A)7

B)8

C) 6

D)9

51106.若有定义:int i=0,x=0;int a[3][3]={1,2,3,4,5,6,7,8,9};则以下程序段运行后x的值为()。C

for (;i<3;i++) x+=a[i][2-i];

A)0

B)12

C)15

D)18

51107.若有定义int a[2][3];则对数组元素的非法引用是()。D

A)a[0][1/2]

B)a[1][1]

C)a[4-4][0]

D)a[0][3]

51108.以下数组定义中,正确的是()。C

A)int a[2][]={1,2,3,4,5};

B)int a[][2]={{0},{}};

C)int a[2][2]={{1,2},{3}};

D)int a[][]={1,2,3,4};

51109.若有定义int a[][3]={1,2,3,4,5,6,7,8,9};则表达式sizeof(a)/sizeof(a[0])的值为()。D

A) 3

B) 4

C) 5

D)9

51201.设有以下变量定义: char

str1[]="string",str2[8],*str3,*str4="string ";

()是正确的。A

A)strcpy(str1,"China");

B)str2="China";

C)strcpy(*str3,"China");

D)strcpy(str4[0],"China");

51202.有如下定义:

char

str[6]={‘a’,’b’,’\0’,’e’,’f’};

则语句:printf(“%s”,str);的输出结果是()。D

A)ab\

B)abdef

C)ab\0

D)ab

51203.设有如下数组定义:

char str[8]={ "FuJian"};

则分配给数组str的存储空间是()个字节。C

A) 6

B)7

C)8

D)9

51204.若有定义:char a[]="abcdef";char b[]="xyz";则以下程序段运行后屏幕输出为()。B

strcpy(a,b);

printf("%c",a[2]);

A) c

B)z

C)\0

D) d

51205.以下程序段运行后屏幕输出为()。C char a[]="abc\0mis";

printf("%d",strlen(a));

A) 5

B)8

C) 3

D) 4

51206.若有定义:int a=2;则语句a=strcmp("miss","miss");运行后a的值为().B

A) 1

B)0

C)-1

D) 2

51207.以下程序段运行后屏幕输出为()。B

char str[]="ab\\cd";

printf("%d",strlen(str));

A) 4

B) 5

C) 6

D)7

51208.以下程序段运行后屏幕输出为()。A char

str[80];strcpy(str,"hello");printf("%d",str len(str));

A) 5

B) 6

C)7

D)80

51209.若有定义:char str1[6]="abcdm",*ps,*str2="abcdef";()是正确的。B

A)strcpy(str1,str2);

B)表达式strcmp(str1,str2)的值大于0

C)str1=str2;

D)表达式strlen(str1)的值为6

51301. 设有如下函数定义:

int fun(char *str)

{ char *p=str;

while ( *p != '\0') p++;

return (p-str);

}

则以下语句执行后的输出结果是()。A

printf("%d\n",fun("Student"));

A)7

B)8

C)9

D)10

51302.以下程序的运行结果是()。A

int fun(int array[4][4])

{ int j;

for(j=0;j<4;j++)

printf("%2d",array[2][j]);

printf("\n");

}

main() { int a[4][4]={0,1,2,0,1,0,0,4,2,0,0,5,0,4,5,0}; fun(a);

}

A) 2 0 0 5

B) 1 0 0 4

C)0 1 2 0

D)0 4 5 0

51303.如下fun函数的类型是()。C

fun(float x)

{double y; int z ;

y=x * x ;

z=(int)y ;

return(z);

}

A)void

B)double

C)int

D)float

51304.以下程序运行后屏幕输出为()。B #include

int f(int x,int y)

{

return(x+y);

}

main()

{

int a=2,b=3,c;

c=f(a,b);

printf("%d+%d=%d\n",a,b,c);

}

A)0

B)2+3=5

C)2+3=0

D)3+2=5

51305.以下程序运行后屏幕输出为()。D #include

int a=2,b=3;

int max(int a,int b)

{

int c;

c=a>b?a:b;

return(c);

}

main()

{

int a=4;

printf("%d",max(a,b));

}

A)2,3

B) 2

C) 3

D) 4

51306.以下程序运行后屏幕输出为()。B #include

void f(int i)

{

int a=2;

a=i++;

printf("%d,",a);

}

main()

{

int a=1,c=3;

f(c);

a=c++;

printf("%d",a);

}

A)4,3

B)3,3

C)4,5

D)3,5

51307.若有如下函数定义:

int fun()

{

static int k=0;

return ++k;

}

以下程序段运行后屏幕输出为()。D

int i;

for(i=1;i<=5;i++) fun();

printf("%d",fun());

A)0

B) 1

C) 5

D) 6

51308.下面程序的输出结果是()。D

#include int global=100;

fun()

{

int global=5;

return ++global;

}

void main()

{

printf(“%d\n”,fun());

}

A)100

B)101

C) 5

D) 6

51309.下列关于C语言函数的描述中,正确的是()。B

A)函数的定义可以嵌套,但函数的调用不可以嵌

B)函数的定义不可以嵌套,但函数的调用可以嵌

C)函数的定义和函数的调用都可以嵌套

D)函数的定义和函数的调用都不可以嵌套51401.若有以下宏定义,

#define MOD(x,y) x%y

则执行以下程序段后,z的值是()。D

int z,a=15,b=100;

z=MOD(b,a);

A)100

B)15

C)11

D)10

51402.以下叙述中,正确的是()。B

A)“#define PRICE=30”定义了与30等价的符

号常量PRICE

B)预编译处理命令行都必须以“#”开头

C)宏名只能包含大写字母和数字字符

D)在程序的一行上可以书写几个有效的宏定义51403.以下叙述中,正确的是()。A

A)宏展开不占用运行时间,只占用编译时间

B)预编译处理命令行必须以分号结束

C)一个源程序只能有一个预编译处理命令行

D)使用带参数的宏定义时,应该说明每个参数的

数据类型

51404.以下的叙述不正确的是().C

A)宏展开不占用运行时间,只占用编译时间

B)宏名无类型

C)宏名必须用大写字母表示

D)预处理命令行都必须以#号开始

51405.若有定义:#define PI 3,则表达式PI*2*2的值为()。A

A)12

B) 4

C) 3

D)不确定

51406.以下程序运行后,屏幕输出为()。C

#define MIN(a,b) ((a)<(b)?(a):(b))

main()

{int x=2,y=3,z;

z=2*MIN(x,y);

printf("%d",z);

}

A) 2

B) 3

C) 4

D) 6

51407.下面程序的是出结果是()。A

#include

#define SQR(x) (x*x)

void main()

{ int a,b=3;

a=SQR(b+2);

printf("\n%d",a);

}

A)11

B)25

C)不定值

D)产生错误

51408.下面程序的输出结果是()。C

#include

#define ONE 1

#define TWO ONE+1

#define THREE TWO+1

void main()

{

printf("%d\n",THREE-ONE);

}

A)产生错误

B) 1 C) 2

D) 3

51409.以下叙述正确的是()。B

A)预处理命令行必须位于C源程序的起始位置

B)在C语言中,预处理命令行都以"#"开头

C)每个C程序必须在开头包含预处理命令行:

#include

D)C语言的预处理不能实现宏定义和条件编译的

功能

51501.设有以下语句,则()是对a数组元素的不正确引用,其中0≤i<10。D

int a[10]={0,1,2,3,4,5,6,7,8,9}, *p=a;

A)a[p-a]

B)*(&a[i])

C)p[i]

D)*(*(a+i))

51502.对于基类型相同的两个指针变量之间,不能进行的运算是()。C

A)<

B)=

C)+

D)-

51503.执行以下程序段的输出结果是()。B int a=10,*p=&a;

printf("%d",++*p);

A)10

B)11

C)变量a的地址

D)变量a的地址 + 1

51504.以下程序段运行后*(p+3)的值为()。A char a[]="good";

char *p;

p=a;

A)'d'

B)'\0'

C)存放'd'的地址

D)'o'

51505.以下程序段运行后*(++p)的值为()。C char a[5]="work";

char *p;

p=a;

A)'w'

B)存放'w'的地址

C)'o'

D)存放'o'的地址

51506.若有定义:int *p,a=4; p=&a;则以下均代表地址的是()。B

A)a,p

B)&a,p

C)&a,*p

D)a,*p

51507.若有说明语句:double *p,a;则能通过scanf语句正确给输入项读入数据的程序段是()。D

A)*p=&a;scanf("%lf",p);

B)*p=&a;scanf("%lf",*p);

C)p=&a;scanf("%lf",*p);

D)p=&a;scanf("%lf",p);

51508.在16位编译系统上,若有定义int a[]={10,20,30},*p=&a;当执行p++;后下列叙述错误的是()。A

A)p向高地址移了一个字节

B)p与a+1等价

C)语句printf("%d",*p);输出20

D)p指向数组元素a[1]

51509.下面语句正确的是()。B

A)int *p; *p=20;

B)char *s="abcdef"; printf("%s\n",s);

C)char str[]="abcd"; str++;

D)char

str[]={'a','b','c'};printf("%s",str); 51601.若有以下程序段,且0≤i<4,0≤j<3,则不能正确访问a数组元素的是()。D

int i,j,(*p)[3];

int a[][3]={1,2,3,4,5,6,7,8,9,10,11,12};

p = a;

A)*(*(a+i)+j)

B)p[i][j]

C)(*(p+i))[j]

D)p[i]+j

51602.若函数fun的函数头为:int fun(int i,int j)且函数指针变量p定义如下:int(*p)(int i,int j);

则要使指针p指向fun的赋值语句是()。

B

A)p=*fun;

B)p=fun;

C)p=fun(i,j); D)p=&fun;

51603.设有如下变量定义:

char aa[][3]={'a','b','c','d','e','f'}; char (*p)[3]=aa;

则以下程序段的运行结果是()。D

p++;

printf("%c",**p);

A) a

B) b

C) c

D) d

51604.以下程序段运行后x的值为()。D int a[]={1,2,3,4,5,6,7,8};

int i,x,*p;

x=1;

p=&a[2];

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

x*=*(p+i);

A)不确定

B)24

C)120

D)60

51605以下程序段运行后x的值为()。B int a[]={1,2,3},b[]={4,2,5};

int *p,*q;

int i,x;

p=a; q=b;

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

if(*(p+i)==*(q+i))

x=*(p+i)*2;

A) 2

B) 4

C) 6

D)不确定

51606.以下程序段运行后x的值为()。C int a[9]={1,2,3,4,5,6,3,8,9};

int *p,*q;

int i,x;

p=&a[0];

q=&a[8];

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

if(*(p+i)==*(q-i))

x=*(p+i)*2;

A) 2

B) 4

C) 6

D)不确定

51607.下面程序的输出结果是()。A

#include

void main()

{

int i;

char *s="abc";

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

printf("%s\n",s+i);

}

A)abc

bc

c

B) c

bc

abc

C)abc

c

bc

D) a

ab

abc

51608.下面程序的输出结果是()。A

#include

void main()

{

char *str="12345",*ps=str+4;

printf("%c\n",ps[-4]);

}

A) 1

B) 2

C) 3

D)错误

51609.以下程序执行时,输入1 2 3 4 5<回车>,输出为:()。A

#include

#define N 5

void main()

{ int a[N];

int *p=a;

while(p

while(p>a) printf("%d",*(--p)); }

A) 5 4 3 2 1

B) 1 2 3 4 5

C) 2 3 4 5 1

D) 4 3 2 1 5

51701.设有以下定义语句:

struct student

{ int num;

char name[10];

float score;

} wang,zhang;

则不正确的叙述是()。C

A)struct是结构体类型的关键字

B)zhang是结构体变量名

C)wang是结构体类型名

D)num,name,score都是结构体类型student

的成员名

51702.设有以下定义语句:

struct student

{ int num;

char name[10];

float score;

} wang,zhang;

则变量wang所占的内存字节数是()。B

A)14

B)16

C)18

D)20

51703.设有如下定义语句:

union u_type

{ int i;

double x;

float f;

};

struct str_type

{ char str[100];

union u_type u[2];

};

则语句“printf("%d", sizeof(struct str_type));”的输出结果是()。B

A)100

B)116

C)120

D)200

51704.若有定义:

struct teacher

{int num;

char name[10];

char sex;

int age;

float score;

}teacher1;

则变量teacher1所占用的内存字节数是()。C

A) 5

B)14

C)19

D)20

51705.下列对结构体类型变量定义不正确的是()。C

A)struct teacher

{ int num;

int age;

}teach1;

B)struct

{ int num;

int age;

}teach1,teach2;

C)struct

{ int num;

int age;

}teacher;

struct teacher teach1;

D)struct teacher

{ int num;

int age;

};

struct teacher teach1;

51706.若有定义:

struct teacher

{ int num;

char sex;

int age;

}teacher1;

则下列叙述不正确的是()。D

A)struct是结构体类型的关键字

B)struct teacher是用户定义的结构体类型

C)num,sex,age都是结构体变量teacher1的成

员D)teacher1是结构体类型名

51707.以下程序的运行结果是()。D

#include

union Utype{

int i;

float f;

}u[2];

void main()

{

printf("sizeof(u):%d\n",sizeof(u));

}

A) 2

B) 4

C) 6

D)8

51708.以下程序的运行结果是()。D

#include

union Utype{

int i;

float f;

};

struct{

char ch[2];

int i;

union Utype u;

}a;

void main()

{

printf("sizeof(a):%d\n",sizeof(a));

}

A) 5

B) 6

C)7

D)8

51709.以下C语言共用体类型数据的描述中,不正确的是()。D

A)共用体变量占的内存大小等于所需内存最大

的成员所占的内存

B)共用体类型可以出现在结构体类型定义中

C)在定义共用体变量的同时允许对第一个成员

的值进行初始化

D)同一共用体中各成员的首地址不相同51801.若有以下定义:

struct link

{ int data; struct link *next; }*head, *p; 并已建立如下图所示的链表结构: ┌──┬──┐ ┌──┬──┐ ┌──┬──┐ head →│data │next ┼→│data │next ┼→...─→│data │NULL │ └──┴──┘ └──┴──┘ └──┴──┘ 指针p 指向如下结点: ┌──┬──┐ p →│data │next │ └──┴──┘ 则能够把p 所指结点插入到链表中成为链表第2个结点的程序段是( )。A A) p->next = head->next; head->next = p ; B) head->next = p; p->next = head->next; C) p.next = head.next; head.next = p; D) (*head).next = p; (*p).next = (*head).next; 51802.若有以下定义: struct link { int data; struct link *next; }a,b,c, *head, *p; 其中,指针head 指向变量a, p 指向变量c ,a.next 指向变量b ,链表结构如下图所示: a b c ┌──┬──┐ ┌──┬──┐ ┌──┬──┐ head →│data │next ┼→│data │NULL │ p →│data │next │ └──┴──┘ └──┴──┘ └──┴──┘ 则能够把c 插入到a 和b 之间并形成新链表的程序段是( )。D A) a.next = c; c.next = b; B) head.next = p; p.next = head.next; C) head->next = &c; p->next = head->next; D) (*head).next = p; (*p).next = &b; 51803.若有以下定义: struct link { int data; struct link *next; } *head, *p; 并已建立如下图所示的链表结构: p ↓ ┌──┬──┐ ┌──┬──┐ ┌──┬──┐ head →│data │next ┼→│data │next ┼→...─→│data │NULL │ └──┴──┘ └──┴──┘ └──┴──┘ 则能保留链表其它结点,而删除p 所指向结点的程序段是( )。A A) head->next = p->next; free(p); A) head->next = p; p->next = head->next; free(p); B) free(p); head->next = p; p->next = head->next; C) free(p); head->next = p->next;

51804.若有定义: struct node { int data; struct node *next; }; 及函数: void fun(struct node *head) { struct node *p=head; while(p) { struct node *q=p->next; free(p); p=q; } } 调用时head 是指向链表首结点的指针,整个链表的结构如下图: ┌─┬─┐ ┌─┬─┐ ┌─┬─┐ head →│2 │ ┼→│15│ ┼→ … →│27│ ┼→NULL └─┴─┘ └─┴─┘ └─┴─┘ 则函数fun()的功能是( )。A A) 删除整个单向链表

B)删除单向链表中的一个结点

C)显示单向链表中的所有数据

D)创建单向链表

51805.若有定义:

struct node

{ int data;

struct node *next;

};

及函数:

void fun(struct node * head)

{ struct node * p = head;

while(p)

{

printf("%d ", p->data );

p = p->next;

break;

}

}

调用时head是指向链表首结点的指针,整个链表的结构如下图:

┌─┬─┐┌─┬─┐┌─┬─┐

head →│5 │┼→│17│┼→…→│38│┼→NULL

└─┴─┘└─┴─┘└─┴─┘

则函数fun()的功能是()。C

A)删除单向链表

B)显示单向链表中的所有数据

C)显示单向链表中的第一个数据

D)创建单向链表

51806. 若有定义:

struct node

{ int data;

struct node *next;

};

及函数:

void fun(struct node * head)

{ struct node * p = head;

while(p)

{

printf("%d ", p->data );

p = p->next;

} }

调用时head是指向链表首结点的指针,整个链表的结构如下图:

┌─┬─┐┌─┬─┐┌─┬─┐

head →│5 │┼→│17│┼→…→│38│┼→NULL

└─┴─┘└─┴─┘└─┴─┘

则函数fun()的功能是()。B

A)删除单向链表

B)显示单向链表中的所有数据

C)显示单向链表中的第一个数据

D)创建单向链表

51807.若有如下定义,函数fun的功能是()。B 其中head指向链表首结点,整个链表结构如下图:┌──┬─┐┌──┬─┐┌──┬──┐

head →│data│┼→│data│┼→…→│data│NULL│

└──┴─┘└──┴─┘└──┴──┘

struct node{

int data;

struct node *next;

};

int fun(struct node* head)

{

int n=0;

struct node* t=head;

while(t!=NULL)

{

n++;

t=t->next;

}

return n;

}

A)删除链表head中的所有结点

B)计算链表head中结点的个数

C)插入一个元素到链表head中

D)创建一个链表head

51808.若有如下定义,函数fun的功能是()。A 其中head指向链表首结点,整个链表结构如下图:

┌──┬─┐┌──┬─┐┌──┬──┐

head →│data│┼→│data│┼→…→│data│NULL│

└──┴─┘└──┴─┘└──┴──┘

struct node{

int data;

struct node *next;

};

void fun(struct node* head)

{

struct node* t=head;

while(t!=NULL)

{

if(t->data%2==0)

printf("%d ",t->data);

t=t->next;

}

}

A)遍历链表head,输出表中值为偶数的元素

B)建立一个只有表头结点的链表head

C)删除链表head中的第一个结点

D)插入一个元素到链表head中

51809.下面程序的输出结果是()。A

#include

#include

typedef struct node{

int data;

struct node *next;

}Node;

Node

list[3]={{1,&list[1]},{2,&list[2]},{3,0}}; void print(Node* head)

{

Node* t=head;

while(t!=NULL)

{

printf("%d ",t->data);

t=t->next;

}

}

void main()

{ print(list);

}

A) 1 2 3

B)0 1 2

C)0 1 3

D) 2 3 0

51901.对枚举类型进行定义,不正确的是()。A

A)enum b{1, 2, 3};

B)enum a{A, B, C};

C)enum c{D=3, E, F};

D)enum d{X=0, Y=5, Z=9};

51902.假定已有如下变量说明和枚举定义:

char ch ;

int j, k ;

enum day{sun, mon, tue, wed, thu, fri, sat} ;

int a[sat];

判断下列语句是否符合语法规则,结果是()。C

char a ; /* 语句1 */ j + k = j ; /* 语句2 */ if(a[mon]>0) j ++ ; /* 语句3 */

A)语句2错误,其它正确

B)语句1正确,其它错误

C)语句3正确,其它错误

D)语句1错误,其它正确

51903.设有如下定义:

typedef int *INTEGER;

INTEGER p,*q;

则()是正确的叙述。C

A)p是int型变量

B)q是基类型为int的指针变量

C)p是基类型为int的指针变量

D)程序中可用INTEGER代替int类型名51904.在对于无符号数的位运算中,操作数右移一位相当于()。A

A)操作数除以2

B)操作数乘以2

C)操作数除以4

D)操作数乘以4

51905.若有定义:int a=20,b=28,c;则执行语句c=(a^b)<<2;后c的值为()。C

A) 2

B) 5

C)32

D)92

51906.若有定义:int a=20,b=28,c;则执行语句c=(a&b)>>2;后c的值为()。A

A) 5

B)7

C)80

D)112

51907.下面程序的输出结果为()。B

#include

void main()

{

enum

Weekday{sun=7,mon=1,tue,wed,thu,fri,sat};

enum Weekday day=sat;

printf("%d\n",day);

}

A)7

B) 6

C) 5

D) 4

51908.若有以下类型说明,叙述正确的是()。C typedef struct

{

int num;

char *name;

int score;

}STU,*PSTU;

A)STU是变量名

B)PSTU是变量名

C)PSTU是指向结构体类型STU的指针类型名

D)类型说明语句有错误

51909.下面程序段的运行结果是()。C

int a=5,b=6;

printf("%d",a|b);

A) 5

B) 6

C)7

D)8

52001.以下程序的功能是()。C

#include

main()

{ FILE *fp; long int n;

fp=fopen("wj.txt","rb");

fseek(fp,0,SEEK_END);

n=ftell(fp);

fclose(fp);

printf("%ld",n);

}

A)计算文件wj.txt的起始地址

B)计算文件wj.txt的终止地址

C)计算文件wj.txt内容的字节数

D)将文件指针定位到文件末尾

52002.标准函数fgets(s, n, f)的功能是()。B

A)从文件f中读取长度为n的字符串存入指针s

所指的内存

B)从文件f中读取长度不超过n-1的字符串存入

指针s所指的内存

C)从文件f中读取n个字符串存入指针s所指的

内存

D)从文件f中读取长度为n-1的字符串存入指针

s所指的内存

52003.以下程序的可执行文件名是file.exe。

main(int argc,char * argv[])

{ int i;

for(i=2;i

printf("%s%c",argv[i],(i

':'\n');

}

在DOS命令行输入:file My C Language and Programming<回车>,其输出结果是()。A

A) C Language and Programming

B)My C Language and Programming

C)MyCLanguageandProgramming

D)file My C Language and Programming 52004.以下程序的可执行文件名为tt.exe,若程序运行后屏幕显示:3, We are,则在DOS提示符下输入的命令是()。C

void main(int argc, char * argv[])

{

int i;

printf("%d,",argc);

for(i=1;i

printf("%s ",argv[i]);

}

A)tt

B)tt We

C)tt We are

D)tt We are happy!

52005.以下程序运行后,屏幕显示write ok!,下列说法正确的是()。D

#include

main()

{ FILE *fp;

fp=fopen("data.txt", "wt");

if(fp!=NULL)

{ fprintf(fp,"%s\n", "File write successed!\n");

fclose(fp);

printf("write ok!\n");

}

}

A)当前工作目录下存在data.txt文件,其中的

内容是"write ok!"

B)fclose(fp);语句的功能是打开文件

C)当前工作目录下一定不存在data.txt文件

D)当前工作目录下一定存在data.txt文件52006.以下程序运行后,屏幕显示File open error!,则可能的原因是()。C

#include

main()

{

FILE *fp;

char str[256];

fp = fopen("test.txt", "rt");

if(fp==NULL)

{ printf("File open error!");

return;

}

fscanf(fp,"%s",str);

fclose(fp);

}

A)当前工作目录下有test.txt文件,但

test.txt文件太小

B)test.txt文件不能关闭

C)当前工作目录下没有test.txt文件

D)当前工作目录下有test.txt文件,但

test.txt文件太大

52007.以下程序的可执行文件名为cmdline.exe。#include

#include

void main(int argc,char *argv[])

{

if(argc!=2)

{

printf("You forgot to type your name or you typed more parameters\n");

exit(1);

}

printf("Hello %s\n",argv[1]);

}

在DOS命令行输入:cmdline harry<回车>,则输出结果是()。B

A)You forgot to type your name or you typed

more parameters

B)Hello harry

C)Hello cmdline

D)hello

52008.对下面程序正确的描述是()。C

#include

#include

void main()

{

FILE *in,*out;

if((in=fopen("infile.txt","r"))==NULL)

{

printf("cannot open infile\n");

exit(0);

}

if((out=fopen("outfile.txt","w"))==NULL)

{

printf("cannot open outfile\n");

exit(0);

}

while(!feof(in))

fputc(fgetc(in),out);

fclose(in);

fclose(out);

}

A)程序实现在屏幕上显示磁盘文件infile.txt

的内容

B)程序实现将两个磁盘文件infile.txt和

outfile.txt的内容合二为一

C)程序实现将磁盘文件infile.txt复制到磁盘

文件outfile.txt

D)程序实现将两个磁盘文件合并并在屏幕上输

52009.以下叙述中正确的是().D

A)C语言中的文件是流式文件,因此只能顺序存

取数据

B)打开一个已存在的文件进行了写操作后,原有

文件中的全部数据必定被覆盖

C)在一个程序中当对文件进行了写操作后,必须

先关闭该文件然后再打开,才能读到第1个数

D)当对文件的写操作完成之后,必须将它关闭,

否则可能导致数据丢失

历年二级C语言笔试真题及答案

1 2009年9月全国计算机等级考试二级笔试 试卷 1)下列数据结构中,属于非线性结构的是 A )循环队列 B) 带链队列 C) 二叉树 D )带链栈 2)下列数据结果中,能够按照“先进后出”原则存取数据的是 A) 循环队列 B) 栈 C)队列 D)二叉树 3)对于循环队列,下列叙述中正确的是 A )队头指针是固定不变的 B )队头指针一定大于队尾指针 C )队头指针一定小于队尾指针 D )队头指针可以大于队尾指针,也可以小于队尾指针 4)算法的空间复杂度是指 A )算法在执行过程中所需要的计算机存储空间 B )算法所处理的数据量 C )算法程序中的语句或指令条数 D )算法在执行过程中所需要的临时工作单元数 5)软件设计中划分模块的一个准则是 A) 低内聚低耦合 B) 高内聚低耦合 C) 低内聚高耦合 D) 高内聚高耦合 6)下列选项中不属于结构化程序设计原则的是 A) 可封装 B) 自顶向下 C) 模块化 D) 逐步求精 7)软件详细设计产生的图如下: 该图是 A) N-S 图 B) PAD 图 C) 程序流程图 D) E-R 图 8)数据库管理系统是 A )操作系统的一部分B) 在操作系统支持下的系统软件C) 一种编译系统 D) 一种操作系统 9)在E-R 图中,用来表示实体联系的图形是 A) 椭圆图B) 矩形C) 菱形D) 三角形 10)有三个关系R ,S 和T 如下: 其中关系T 由关系R 和S 通过某种操作得到,该操作为 A) 选择 B) 投影 C) 交 D) 并 11)以下叙述中正确的是 A )程序设计的任务就是编写程序代码并上机 B )程序设计的任务就是确定所用数据结 构 C )程序设计的任务就是确定所用算法 D )以上三种说法都不完整 12)以下选项中,能用作用户标识符的是 A )void B )8_8 C )_0_ D )unsigned 13)阅读以下程序 #include main() { int case; float printF; printf(“请输入2个数:”); scanf(“%d %f”,&case,&pjrintF); printf(“%d %f \n”,case,printF); } 该程序编译时产生错误,其出错原因是 A )定义语句出错,case 是关键字,不能 用作用户自定义标识符B )定义语句出错,printF 不能用作用户自定义标识符 C )定义语句无错,scanf 不能作为输入函 数使用 D )定义语句无错,printf 不能输出case 的值 14)表达式:(int)((double)9/2)-(9)%2的值是 A )0 B )3 C )4 D )5 15)若有定义语句:int x=10;,则表达式 x-=x+x 的值为 A )-20 B )-10 C )0 D )10 16)有以下程序 #include main() { int a=1,b=0; printf(“%d,”,b=a+b); printf(“%d \n”,a=2*b); } 程序运行后的输出结果是 A )0,0 B )1,0 C )3,2 D )1,2 17)设有定义:int a=1,b=2,c=3;,以下语 句中执行效果与其它三个不同的是 A )if(a>b) c=a,a=b,b=c; B )if(a>b) {c=a,a=b,b=c;} C ) if(a>b) c=a;a=b;b=c; D ) if(a>b) {c=a;a=b;b =c;} 18)有以下程序 #include main() { int c=0,k; for (k=1;k<3;k++) switch (k) {default: c+=k case 2: c++;break; case 4: c+=2;break; } printf(“%d \n”,c); } 程序运行后的输出结果是 A )3 B )5 C )7 D )9 19)以下程序段中,与语句:k=a>b?(b>c?1:0):0;功能相同的是 A )if((a>b)&&(b>c)) k=1;else k=0; B )if((a>b)||(b>c) k=1;else k=0; C )if(a<=b) k=0;else if(b<=c) k=1; D )if(a>b) k=1;else if(b>c) k=1; else k=0; 20)有以下程序 #include main() { char s[]={“012xy”};int i,n=0; for(i=0;s[i]!=0;i++) if(s[i]>=?a?&&s[i]<=?z?) n++; printf(“%d \n”,n); } 程序运行后的输出结果是 A )0 B )2 C )3 D )5 21)有以下程序 #include main() { int n=2,k=0; while(k++&&n++>2); printf(“%d %d \n”,k,n); } 程序运行后的输出结果是 A )0 2 B )1 3 C )5 7 D )1 2 22)有以下定义语句,编译时会出现编译错误的是 A )char a=?a? B )char a=?\n?; C )char a=?aa?; D )char a=?\x2d?; 23)有以下程序 #include main() { char c1,c2; c1=?A?+?8?-…4?; c2=?A?+?8?-…5?; printf(“%c,%d \n”,c1,c2); } 已知字母A 的ASCII 码为65,程序运行后的输出结果是

C语言练习试题和答案

单项选择题: 1.(A)是构成C语言程序的基本单位。 A、函数 B、过程 C、子程序 D、子例程 2.C语言程序从 C开始执行。 A) 程序中第一条可执行语句 B) 程序中第一个函数 C) 程序中的main函数 D) 包含文件中的第一个函数 3、以下说法中正确的是(C)。 A、C语言程序总是从第一个定义的函数开始执行 B、在C语言程序中,要调用的函数必须在main( )函数中定义 C、C语言程序总是从main( )函数开始执行 D、C语言程序中的main( )函数必须放在程序的开始部分 4.下列关于C语言的说法错误的是(B )。 A) C程序的工作过程是编辑、编译、连接、运行 B) C语言不区分大小写。 C) C程序的三种基本结构是顺序、选择、循环 D) C程序从main函数开始执行 5.下列正确的标识符是(C)。 [i] t 6.下列C语言用户标识符中合法的是( B)。 A)3ax B)x C)case D)-e2 E)union 7.下列四组选项中,正确的C语言标识符是(C)。 A) %x B) a+b C) a123 D) 123 8、下列四组字符串中都可以用作C语言程序中的标识符的是(A)。 A、print _3d db8 aBc B、I\am one_half start$it 3pai C、str_1 Cpp pow while D、Pxq My->book line# 语言中的简单数据类型包括(D)。 A、整型、实型、逻辑型 B、整型、实型、逻辑型、字符型 C、整型、字符型、逻辑型 D、整型、实型、字符型 10.在C语言程序中,表达式5%2的结果是C。 A) B)2 C)1 D)3 11.如果int a=3,b=4;则条件表达式"a

C语言选择题题库

C语言程序设计题库说明 一本题库适用对象 计算机应用技术计算机软件软件技术计算机网络技术与计算机控制技术等专业 二本题库包含有175道选择题 三本题库所有题目均附有答案

一、选择题 下列各题ABCD四个选项中,只有一个选项是正确的,请将正确选项涂在答题卡的相应位置上,答在试卷上不得分。 1、不合法的整数是()。 A)0x35 B)43.6 C)0532 D)-346 2、下列合法的字符常量是()。 A)“f” B)x C)65 D)‘\Xab’ 3、设有整型变量x,单精度变量y=,表达式x=float(y*3+((int)y%4))执行后,x的值为()。 A)17 B)17.500000 C) D) 4、在C语言中,负整数在内存中以()形式释放。 A)补码 B)BCD码 C)反码 D)十进制数 5、在C语言中,要求参加运算的数必须是整数的运算符是()。 A)/ B)!C)% D)= = 6、()是C语言中非法的数据类型关键字。 A)float B)singed C)integer D)Char

7、现已定义整形变量int i=1;执行循环语句while(i++<5);后i的值为()。 A)1 B)5 C)6 D)以上三个答案都不正确 8、下列语句的输出结果是()。 printf(“%f\n”,(float)(2+4)/2); A)有语法错误不能通过编译 B)3 C)D) 9、C语言中,整数-8在内存中的存储形式是()。 A)1111,1111,1111,1000 B)1000,0000,0000,1000 C)0000,0000,0000,1000 D)1111,1111,1111,0111 10、设C语言中,int类型数据占2个字节,则long类型数据占()个字节。 A)1 B)2 C)8 D)4 11、若变量a已说明为float类型,则能实现将a中的数值保留小数点后两位,第三位进行四舍五入运算的表达式是()。 A)a=(a*100+/ B)a=(a*100+/100 C)a=(int)(a*100+/ D)a=(a/100+*

全国计算机等级考试二级C语言真题

2009年3月二级C语言笔试真题((1)—(10)每小题2分,(11)—(50)每题1分,共60分) 下列各题A)、B)、C)、D)四个选项中,只有一个选项是正确的,请将正确选项涂写在答题卡相应位置上,答在试卷上不得分。 (1)下列叙述中正确的是 A)栈是“先进先出”的线性表 B)队列是“先进先出”的线性表 C)循环队列是非线性结构 D)有序性表既可以采用顺序存储结构,也可以采用链式存储结构 (2)支持子程序调用的数据结构是 A)栈B)树C)队列D)二叉树 (3)某二叉树有5个度为2的结点,则该二叉树中的叶子结点数是 A)10B)8C)6D)4 (4)下列排序方法中,最坏情况下比较次数最少的是 A)冒泡排序 B)简单选择排序 C)直接插入排序 D)堆排序 (5)软件按功能可以分为:应用软件、系统软件和支撑软件(或工具软件)。下面属于应用软件的是 A)编译软件 B)操作系统 C)教务管理系统 D)汇编程序 (6)下面叙述中错误的是 A)软件测试的目的是发现错误并改正错误 B)对被调试的程序进行“错误定位”是程序调试的必要步骤 C)程序调试通常也称为Debug D)软件测试应严格执行测试计划,排除测试的随意性 (7)耦合性和内聚性是对模块独立性度量的两个标准。下列叙述中正确的是 A)提高耦合性降低内聚性有利于提高模块的独立性 B)降低耦合性提高内聚性有利于提高模块的独立性

C)耦合性是指一个模块内部各个元素间彼此结合的紧密程度D)内聚性是指模块间互相连接的紧密程度 (8)数据库应用系统中的核心问题是 A)数据库设计 B)数据库系统设计 C)数据库维护 D)数据库管理员培训 (9)有两个关系R,S如下: 由关系R通过运算得到关系S,则所使用的运算为 A)选择B)投影C)插入D)连接 (10)将E-R图转换为关系模式时,实体和联系都可以表示为A)属性B)键C)关系D)域 (11)以下选项中合法的标识符是 A)1-1B)1—1C)-11D)1-- (12)若函数中有定义语句:intk;,则 A)系统将自动给k赋初值0 B)这时k中值无定义 C)系统将自动给k赋初值-1 D)这时k中无任何值 (13)以下选项中,能用作数据常量的是 A)o115B)0118C))115L (14)设有定义:intx=2;,以下表达式中,值不为6的是A)x*=x+1 B)x++,2*x C)x*=(1+x)

计算机二级c语言历年真题及答案

计算机二级c语言历年真题及答案【篇一:国家计算机二级c语言历年真题及答案】 class=txt>c语言程序设计 (考试时间90分钟,满分100分) 一、选择题((1)—(10)、(21)—(40)每题2分,(11)—(20)每题1分,共70分) (1)下列数据结构中,属于非线性结构的是 a)循环队列 b) 带链队列 c) 二叉树 d)带链栈 (2)下列数据结果中,能够按照“先进后出”原则存取数据的是 a) 循环队列 b) 栈 c)队列 d)二叉树 (3)对于循环队列,下列叙述中正确的是 a)队头指针是固定不变的 b)队头指针一定大于队尾指针 c)队头指针一定小于队尾指针 d)队头指针可以大于队尾指针,也可以小于队尾指针 (4)算法的空间复杂度是指 a)算法在执行过程中所需要的计算机存储空间 b)算法所处理的数据量 c)算法程序中的语句或指令条数 d)算法在执行过程中所需要的临时工作单元数 (5)软件设计中划分模块的一个准则是 a) 低内聚低耦合 b) 高内聚低耦合 c) 低内聚高耦合 d) 高内聚高耦合 (6)下列选项中不属于结构化程序设计原则的是 a) 可封装 d) 自顶向下

c) 模块化 d) 逐步求精 (7)软件详细设计产生的图如下: 该图是 a) n-s图 b) pad图 c) 程序流程图 d) e-r图 (8)数据库管理系统是 a)操作系统的一部分 b) 在操作系统支持下的系统软件 c) 一种编译系统 d) 一种操作系统 (9)在e-r图中,用来表示实体联系的图形是 a) 椭圆图 b) 矩形 c) 菱形 d) 三角形 (10)有三个关系r,s和t如下: 其中关系t由关系r和s通过某种操作得到,该操作为 a) 选择 b) 投影 c) 交 d) 并 (11)以下叙述中正确的是 a)程序设计的任务就是编写程序代码并上机调试 b)程序设计的任务就是确定所用数据结构 c)程序设计的任务就是确定所用算法 d)以上三种说法都不完整 (12)以下选项中,能用作用户标识符的是 a)void b)8_8 c)_0_ d)unsigned (13)阅读以下程序

c语言试题及答案

1、以下正确的说法是( B ) (A) 用户若需要调用标准库函数,调用前必须重新定义 (B) 用户可以重新定义标准库函数,若如此,该函数将失去原有含义 (C) 系统根本不允许用户重新定义标准库函数 (D) 用户若需调用标准库函数,调用前不必使用预编译命令将该函数所在文件包括到用户源文件中,系统自动去调 2、以下正确的函数声明形式是( A ) (A) double fun(int x, int y) (B) double fun(int x; int y) (C) double fun(int x, int y); (D) double fun(int x,y); 3、以下正确的函数形式是( D ) (A) double fun(int x, int y) { z=x+y; return z;} (B) fun(int x,y) { int z; return z;} (C) fun(x,y) { int x,y; double z; z=x+y; return z;} (D) double fun(int x, int y) { double z; z=x+y; return z;} 4、以下正确的说法是( A ) 在C语言中 (A) 实参和与其对应的形参各占用独立的存储单元 (B) 实参和与其对应的形参共占用一个存储单元 (C) 只有当实参和与其对应的形参同名时才共占用存储单元 (D) 形参是虚拟的,不占用存储单元 5、若调用一个函数,且此函数中没有return语句,则正确的说法是( A ) 该函数 (A) 没有返回值 (B) 返回若干个系统默认值 (C) 能返回一个用户所希望的函数值 (D) 返回一个不确定的值 6、以下不正确的说法是( B ) C语言规定 (A) 实参可以是常量、变量和表达式 (B) 形参可以是常量、变量和表达式 (C) 实参可以为任意类型 (D) 形参应与其对应的实参类型一致 7、以下正确的说法是( C ) (A) 定义函数时,形参的类型说明可以放在函数体内 (B) return后边的值不能为表达式 (C) 如果函数值的类型与返回值类型不一致,以函数值类型为准 (D) 如果形参与实参的类型不一致,以实参类型为准 8、C语言规定,简单变量做实参时,它和对应形参之间的数据传递方式是( B ) (A) 地址传递 (B) 单向值传递 (C) 由实参传给形参,再由形参传回给实参 (D) 由用户指定传递方式

C语言题库_选择题(1)

本卷共有4道大 一、单项选择题(25道小题,共50分) 1、以下说法中正确的是(C)(2分) A、C语言程序总是从第一个的函数开始执行 B、在C语言程序中,要调用的函数必须在main()函数中定义 C、C语言程序总是从main()函数开始执行 D、C语言程序中的main()函数必须放在程序的开始部分 2、一个算法应该具有“确定性”等五个特性,下面对另外4个特性的描述中错误的是(B)(2分) A、有零个或多个输入 B、有零个或多个输出 C、有穷性 D、可行性 3、以下选项中,不合法常量的是(B)(2分) A、1.234e04 B、1.234e0.4 C、1.234e+4 D、1.234e0 4、C语言中最简单的数据类型包括(B)(2分) A、整型、实型、逻辑型 B、整型、实型、字符型 C、整型、字符型、逻辑型 D、整型、实型、逻辑型、字符型 5、能正确表示逻辑关系:“10≥=a≥=0”的C语言表达式是(D)(2分) A、10>=a>=0 B、a>=0 and a<=10 C、a>=0||a<=10 D、a>=0&&a<=10 6、设a和b均为double型变量,且a=5.5、b=2.5,则表达式(int)a+b/b的值是(D)(2分)A、6.500000B、6 C、5.500000 D、6.000000

7、x、y、z被定义为int型变量,若从键盘给x、y、z输入数据,正确的输入语句是(B)(2分) A、INPUT x、y、z; B、scanf("%d%d%d",&x,&y,&z); C、scanf("%d%d%d",x,y,z); D、read("%d%d%d",&x,&y,&z); 8、设x和y均为int型变量,则以下语句:x+=y;y=x-y;x-=y;的功能是(D)(2分)A、把x和y按从大到小排列B、把x和y按从小到大排列 C、无确定结果 D、交换x和y中的值 9、若有以下程序段:int c1=1,c2=2,c3;c3=1.0/c2*c1;则执行后,c3中的值是(A)(2分)A、0B、0.5 C、1 D、2 10、设char ch='A';则ch=(ch>='A'&&ch<='Z')?(ch+32):ch的值是(B)。(2分) A、A B、a C、Z D、z 11、执行程序段int a=-1,b=4,k;k=(++a<0)&&!(b-- <=0);printf(“%d %d %d\n”,k,a,b);后的输出结果是(D )。 (2分) A、1 0 4 B、1 0 3 C、0 0 3 D、0 0 4 12、设intx=1, y=1;表达式(!x||y--)的值是(B)。(2分) A、0B、1 C、2 D、-1 13、程序段intx=3;do{printf(“%d”,x-=2);}while(!(--x));的输出结果是(C)。(2分) A、1 B、30 C、1-2 D、死循环

二级C语言试题(含答案)

二级C语言试题 一、判断题(2×8=16分) 1、printf()函数总是从新行的起始位置开始打印。( F ) 2、所有的变量在使用前都必须予以申明。(F) 3、在申明变量时必须给出变量的类型。(T) 4、C语言认为变量number和NuMbEr是相同的。( F) 5、打印三行输出的C语言程序必须用三条printf语句。(F) 6、求余运算符%只能用于两个整数操作数。(T) 7、switch选择结构中必须有default子句。(F) 8、如果x>y或ay&&a

C语言试卷及答案

一、选择题(每题 1 分,共 20 分) 1. C 语言程序的三种基本结构是顺序结构、选择结构和结构。 A、循环 B、递归 C、转移 D、嵌套 2. 下列标识符中,合法的是_______ 。 A) unsigned B) 5ab C) INT# D)_num2 3. 若float x ;x = 10/4 ;x的值是。 A、2.5 B、2.0 C、3 D、 2 4. 表达式!x 等价于。 A、x==0 B、x==1 C、x != 0 D、x != 1 5. 算术运算符、赋值运算符和关系运算符的运算优先级按从高到低的顺序依次为。 A、算术运算、赋值运算、关系运算 B、关系运算、赋值运算、算术运算 C、算术运算、关系运算、赋值运算 D、关系运算、算术运算、赋值运算 6. 能将高级语言编写的源程序转换为目标程序的是。 A、链接程序 B、解释程序 C、编译程序 D、编辑程序 7. 下列语句定义pf为指向float类型变量f的指针,是正确的。 A、float f, *pf = f; B、float f, *pf = &f; C、float *pf = &f, f; D、float f, pf = f; 8. 一个C程序的执行是从。 A、本程序的main函数开始,到main函数结束 B、本程序文件的第一个函数开始,到本程序文件的最后一个函数结束 C、本程序的main函数开始,到本程序文件的最后一个函数结束 D、本程序文件的第一个函数开始,到本程序main函数结束 9. 能正确表示“当x的取值在[1,10]或[[200,210]范围内为真,否则为假”的表达式是________。 A、(x>=1)&&(x<=10)&&(x>=200)&&(x<=210) B、(x>=1)||(x<=10)||(x>=200)||(x<=210) C、(x>=1)&&(x<=10)||(x>=200)&&(x<=210) D、(x>=1)||(x<=10)&&(x>=200)||(x<=210) 10. 对两个数组a和b进行如下初始化 char a[]=“ABCDEF”;char b[]={ …A?,?B?,?C?,?D?,?E?,?F?}; 则以下叙述正确的是。 A、a和b数组完全相同 B、a和b长度相同 C、a和b中都存放字符串 D、a数组比b数组长度长 11. 是不正确的字符常量。 A、'\n' B、'1' C、"a" D、'\101' 12. 若变量已正确定义,语句“if(a>b) k=0; else k=1;”和等价。 A、k=(a>b)?1:0; B、k=a>b; C、k=a<=b; D、a<=b ? 0 : 1; 13. 设变量定义为“int x, *p=&x;”,则&*p相当于。 A、p B、*p C、x D、*&x 14. 有两个字符数组a、b,则以下正确的输入语句是。 A)gets(a,b); B) scanf(“%s%s”,a,b); C) scanf(“%s%s”,&a,&b); D) gets(“a”),gets(“b”); 15. C语言规定,简单变量做实参时,它和对应形参之间的数据传递方式是。 A、地址传递 B、单向值传递

C语言程序设计期末考试选择题题库

第一章1、一个C程序可能出现的错误有(A)A,以上都包括 B,逻辑错误 C,运行错误 D,语法错误 2、C程序中一般可以包含几个函数(D) A.1个 B.多个 C.0个 D.至少一个 3.C语言属于程序设计语言的哪个类别(B) A.机器语言 B.高级语言 C.面向对象语言 D.汇编语言 4.以下关于C语言描述错误的是(B) A.一个C程序总是从main函数开始执行 B.一个C程序可以包含多个main函数 C.每个语句的最后必须有一个分号 D.C语言的注释符是以"/*"开始并以"*/"结束

5、在调试过程中,逻辑错误是指(C) A.所书写的语句,不符合C的语法。 B.在从obj生成exe文件的过程中,如果函数名书写错误,可能产生的错误。 C.程序的运行结果不符合题目要求。 D.在exe文件的执行过程中,产生运行异常。 第二章 1、16位的二进制数可以表示的整数的范围是(C) A.[-32768,32768] B.[-32767,32768] C.[-32768,32767] D.[-32767,32767] 2、C语言中的实型数据包括(A) A.float和double B.int和float C.float和char D.int和double 3、以下不合法的字符常量是(C) A.'2' B.'A' C.'ab'

4、在以下各组标识符中,均是合法的C语言标识符是(A) A.abc,A_4d,_student,xyz_abc B.auto,12-a,a_b,ab5.x C.A_4d,_student,xyz_abc,if D.abc,a_b,union,scan 5、若有定义:chara;intb;floatc;doubled; 则表达式a*b+d-c值的类型为(A) A.char B.float C.double D.int 6、类型修饰符unsigned不能修饰(D) A.char B.longint C.int D.float 7、若有定义:doublex=1,y; 执行语句,则y的值是(B) A,1 B,2.0

新版计算机二级C语言测试题及答案解析

计算机二级C语言测试题及答案解析计算机二级C语言测试题及答案解析 C语言的应用范围广泛,具备很强的数据处理能力,不仅仅是在软件开发上,而且各类科研都需要用到C语言,下面给大家整理了计算机二级C语言测试题及答案,欢迎阅读! 计算机二级C语言测试题及答案解析 1.(A )是构成C语言程序的基本单位。 A、函数 B、过程 C、子程序 D、子例程 2.C语言程序从 C 开始执行。 A、程序中第一条可执行语句 B、程序中第一个函数 C、程序中的main函数 D、包含文件中的第一个函数 3、以下说法中正确的是( C )。

A、C语言程序总是从第一个定义的函数开始执行 B、在C语言程序中,要调用的函数必须在main( )函数中定义 C、C语言程序总是从main( )函数开始执行 D、C语言程序中的main( )函数必须放在程序的开始部分 4.下列关于C语言的说法错误的是( B ) 。 A、 C程序的工作过程是编辑、编译、连接、运行 B、 C语言不区分大小写。 C、 C程序的三种基本结构是顺序、选择、循环 D、C程序从main函数开始执行 5.下列正确的标识符是(C )。 A、-a1 B、a[i] C、a2_i D、int t 5~8题为相同类型题 考点:标识符的命名规则 只能由字母、数字、下划线构成

数字不能作为标识符的开头 关键字不能作为标识符 选项A中的“-” ,选项B中“[”与“]”不满足(1);选项D中的int 为关键字,不满足(3) 6.下列C语言用户标识符中合法的是(B )。 A、3ax B、x C、case D、-e2 E)union 选项A中的标识符以数字开头不满足(2);选项C,E均为为关键字,不满足(3);选项D中的“-”不满足(1); 7.下列四组选项中,正确的C语言标识符是( C )。 A、 %x B、a+b C、a123 D、123 选项A中的“%” ,选项B中“+”不满足(1);选项D中的标识符以数字开头不满足(2)

全国计算机等级考试 历年真题2009年3月二级C语言笔试真题及答案

全国计算机等级考试历年真题2009年3月二级C语言笔试真题及答案 一、选择题(每题2分,共计70分) 1.(1)下列叙述中正确的是 A)栈是先进先出的线性表 B)队列是"先进后出"的线性表 C)循环队列是非线性结构 D)有序线性表即可以采用顺序存储结构,也可以采用链式存 储结构 A B C D 2.(2)支持子程序调用的数据结构是 A)栈 B)树 C)队列 D)二叉树 A B C D 3.(3)某二叉树有5个度为2的结点,则该二叉树中的叶子结点数是 A)10 B)8 C)6 D)4 A B C D 4.(4)下列排序方法中,最坏情况下比较次数最少的是 A)冒泡排序 B)简单选择排序 C)直接插入排序

D)堆排序 A B C D 5.(5)软件按功能可以分为:应用软件、系统软件和支撑软件(或工具软件)。下列 属于应用软件的是 A)编译程序 B)操作系统 C)教务管理系统 D)汇编程序 A B C D 6.(6)下面叙述中错误的是 A)软件测试的目的是发现错误并改正错误 B)对被调试程序进行"错误定位"是程序调试的必要步骤 C)程序调试也成为Debug D)软件测试应严格执行测试计划,排除测试的随意性 A B C D 7.(7)耦合性和内聚性是对模块独立性度量的两个标准。下列叙述中正确的是 A)提高耦合性降低内聚性有利于提高模块的独立性 B)降低耦合性提高内聚性有利于提高模块的独立性 C)耦合性是指一个模块内部各个元素间彼此结合的紧密程度 D)内聚性是指模块间互相连接的紧密程度 A B C D 8.(8)数据库应用系统中的核心问题是 A)数据库设计 B)数据库系统设计 C)数据库维护 D)数据库管理员培训

(完整版)C语言试题及答案解析

C语言 一、选择题(第题2分,共20分) 1.一个C程序的执行是从 A 。 A) 本程序的main函数开始,到main函数结束 B) 本程序文件的第一个函数开始,到本程序文件的最后一个函数结束 C) 本程序文件的第一个函数开始,到本程序main函数结束 D) 本程序的main函数开始,到本程序文件的最后一个函数结束 2.若x、i、j、k都是int型变量,则计算下面表达式后,x的值为 C 。 x=(i=4,j=16,k=32) A) 4 B) 16 C) 32 D) 52 3.设C语言中,一个int型数据在内存中占2个字节,则unsigned int 型数据的取值范围为 C 。 A) 0~255 B) 0~32767 C) 0~65535 D) 0~2147483647 4.设有说明:char w; int x; float y; double z;则表达式w*x+z-y值的数据类型为 D 。 A) float B) char C) int D) double 5. putchar函数可以向终端输出一个 D 。 A) 整型变量表达式 B) 实型变量值 C) 字符串 D) 字符或字符型变量值 6. printf函数中用到格式符%5s,其中数字5表示输出的字符串占用5列。如果字符串长度大于5,则输出按方式 B ;如果字符串长度小于5,则输出按方式 C 。 A) 从左起输出该字符串,右补空格 B) 按原字符长从左向右全部输出 C) 右对齐输出该字符串,左补空格 D) 输出错误信息 7.判断char型变量ch是否为大写字母的正确表达式是 C 。 A) ‘A’<=ch<=‘Z’ B) (ch>=‘A’)&(ch<=‘Z’) C) (ch>=‘A’)&&(ch<=‘Z’) D) (‘A’<= ch)AND(‘Z’>= ch) 8.已知int x=10,y=20,z=30;以下语句执行后x,y,z的值是 B 。 if(x>y) z=x; x=y; y=z; A) x=10, y=20, z=30 B) x=20, y=30, z=30 C) x=20, y=30, z=10 D) x=20, y=30, z=20 9.以下程序段______C__. x=-1; do{ x=x*x; } while(!x); A)是死循环 B)循环执行二次 C)循环执行一次 D)有语法错误 10.以下正确的描述是___B____. A)continue语句的作用是结束整个循环的执行

C语言试题与答案

大学C语言考试题库 第1章 C语言概述习题 1. 单项选择题 (1) C 语言是在 B 语言的基础上产生的。 A. A B. B C. D D. E (2) 在 C 语言中,每个语句必须以 D 结束。 A. 回车符 B. 冒号 C. 逗号 D. 分号 (3) 标识符和关键字间,要用 C 隔开。 A. 回车符 B. 冒号 C. 空格 D. 分号 (4) 用 C 语言编写的源文件经过编译,若没有产生编译错误,则系统将( B )。 A. 生成可执行目标文件 B. 生成目标文件 C. 输出运行结果 D.自动保存源文件 (5) 下列说法中正确的是( B )。 A. 由于 C 源程序是高级语言程序,因此一定要在 TC 软件中输入 B. 由 C 源程序是字符流组成,因此可以作为文本文件在任何文本编辑的软件中输入 C. 由于C 程序是高级语言程序,因此输入后即可执行 D. 由于 C 程序是高级语言程序,因此它由命令组成 (6) 下列说法中正确的是( A )。 A. C 语言程序由主函数和 0 个或多个函数组成 B. C 语言程序由主程序和子程序组成 C. C 语言程序由子程序组成 D. C 语言程序由过程组成 (7) 下列说法中错误的是( D )。 A. 主函数可以分为两个部分:主函数说明部分和主函数体 B. 主函数可以调用任何非主函数的其他函数 C. 任何非主函数可以调用其他任何非主函数 D. 程序可以从任何非主函数开始执行 2. 填空题 (1) C 语言只有 32 个关键字和 9 种控制语句。 (2) C 语言是一种“中级语言”,既具有高级语言的特点又具有低级语言的特点;既适合于开发系

历年全国计算机二级C语言试题库完整

. . . . 参考 50道C 语言知识题 1.以下叙述中正确的是 A)用C 程序实现的算法必须要有输入和输出操作 B)用C 程序实现的算法可以没有输出但必须要有输入 C)用C 程序实现的算法可以没有输入但必须要有输出 D)用C 程序实现的算法可以既没有输入也没有输出 2.下列可用于C 语言用户标识符的一组是 A)void,define,WORDB)a3_3,_123,Car C)For,-abc,IFCaseD)2a,DO,sizeof 3.以下选项中可作为C 语言合法常量的是 A)-80B)-080C)-8e1.0D)-80.0e 4.若有语句:char*line[5];,以下叙述中正确的是 A)定义line 是一个数组,每个数组元素是一个基类型为char 为指针变量 B)定义line 是一个指针变量,该变量可以指向一个长度为5的字符型数组 C)定义line 是一个指针数组,语句中的*号称为间址运算符 D)定义line 是一个指向字符型函数的指针 5.以下定义语句中正确的是 A)inta=b=0;B)charA=65+1,b=′b′; 6.有以下程序段 charch;intk; ch=′a′; k=12; printf("%c,%d,",ch,ch,k);printf("k=%d\n",k); 已知字符a 的ASCII 码值为97,则执行上述程序段后输出结果是 A)因变量类型与格式描述符的类型不匹配输出无定值 B)输出项与格式描述符个数不符,输出为零值或不定值 C)a,97,12k=12 D)a,97,k=12 7.有以下程序 main() {inti,s=1; for(i=1;i<50;i++) if(!(i%5)&&!(i%3))s+=i; printf("%d\n",s);} 程序的输出结果是 A)409B)277C)1D)91 8.当变量c 的值不为2、4、6时,值也为"真"的表达式是 A)(c==2)||(c==4)||(c==6) B)(c>=2&&c<=6)||(c!=3)||(c!=5) C)(c>=2&&c<=6)&&!(c%2) D)(c>=2&&c<=6)&&(c%2!=1) 9.若变量已正确定义,有以下程序段

计算机二级C语言测试题及答案解析(一)

2016年计算机二级C语言测试题及答案解析(一)1.(A )是构成C语言程序的基本单位。 A、函数 B、过程 C、子程序 D、子例程 2.C语言程序从C 开始执行。 A、程序中第一条可执行语句 B、程序中第一个函数 C、程序中的main函数 D、包含文件中的第一个函数 3、以下说法中正确的是(C )。 A、C语言程序总是从第一个定义的函数开始执行 B、在C语言程序中,要调用的函数必须在main( )函数中定义 C、C语言程序总是从main( )函数开始执行 D、C语言程序中的main( )函数必须放在程序的开始部分 4.下列关于C语言的说法错误的是(B )。 A、C程序的工作过程是编辑、编译、连接、运行 B、C语言不区分大小写。 C、C程序的三种基本结构是顺序、选择、循环 D、C程序从main函数开始执行 5.下列正确的标识符是(C )。

B、a[i] C、a2_i D、int t 5~8题为相同类型题 考点:标识符的命名规则 只能由字母、数字、下划线构成 数字不能作为标识符的开头 关键字不能作为标识符 选项A中的“-”,选项B中“[”与“]”不满足(1);选项D中的int为关键字,不满足(3) 6.下列C语言用户标识符中合法的是(B )。 A、3ax B、x C、case D、-e2 E)union 选项A中的标识符以数字开头不满足(2);选项C,E均为为关键字,不满足(3);选项D中的“-”不满足(1); 7.下列四组选项中,正确的C语言标识符是(C )。 A、%x B、a+b C、a123

选项A中的“%”,选项B中“+”不满足(1);选项D中的标识符以数字开头不满足(2) 8、下列四组字符串中都可以用作C语言程序中的标识符的是(A)。 A、print _3d db8 aBc B、I\am one_half start$it 3pai C、str_1 Cpp pow while D、Pxq My->book line# His.age 选项B中的“\”,”$”,选项D中“>”,”#”,”.”,”-”不满足(1);选项C 中的while为关键字,不满足(3) 9.C语言中的简单数据类型包括(D )。 A、整型、实型、逻辑型 B、整型、实型、逻辑型、字符型 C、整型、字符型、逻辑型 D、整型、实型、字符型 10.在C语言程序中,表达式5%2的结果是C 。 A、2.5 B、2 C、1 D、3 %为求余运算符,该运算符只能对整型数据进行运算。且符号与被模数相同。5%2=1;5%

C语言单项选择题

单项选择题(本大题共20小题,每小题1分,共20分) 1.C++源程序文件扩展名为(A) A..cpp B..h C..1ib D..obj 5.对使用关键字new所开辟的动态存储空间,释放时必须使用(C)A.free B.create C.delete D.realse 6.从本质上看,引用是被引用变量的(B) A.拷贝 B.别名 C.复制 D.克隆 7.在函数调用时,如某一默认参数要指明一个特定值,则有(B) A.其之前所有参数都必须赋值B.其之后所有参数都必须赋值 C.其前、后所有参数都必须赋值D.其前、后所有参数都不必赋值 8.设存在函数int max(int,int)返回两参数中较大值,若求22,59,70三者中最大值,下列表达式不正确的是(C) A.int m=max(22,max(59,70));B.int m=max(max(22,59),70); C.int m=max(22,59,70);D.int m=max(59,max(22,70)); 9.设存在函数int min(int,int)返回两参数中较小值,若求15,26,47三者中最小值,下列表达式中错误的是(B) A.int m=min(min(15,26),min(15,47)); B.int m=min(15,26,47); C.int m=min(15,min(47,26)); D.int m=min(min(47,26),16); 13.函数int&min(int&,int&)返回参数中较小者,设有两整型变量int a=10;int b=15; 在执行语句min(a,b)--;之后,a,b值分别为(B) A.9,14 B.9,15 C.10,14 D.10,15 16.设函数void swap(int&,int&)将交换两形参的值,如两整型变量int a=10;int b=15;则执行swap(a,b)后,a、b值分别为(C) A.10,10 B.10,15 C.15,10 D.15,15

全国计算机等级考试二级C语言真题2013年3月

全国计算机等级考试二级C语言真题2013年3月 (总分40, 做题时间90分钟) 一、选择题 1. 程序流程图中带有箭头的线段表示的是______。 A 图元关系 B 数据流 C 控制流 D 调用关系 答案:C [解析] 在数据流图中,用标有名字的箭头表示数据流。在程序流程图中,用标有名字的箭头表示控制流。所以选择C。 2. 结构化程序设计的基本原则不包括______。 A 多态性 B 自顶向下 C 模块化 D 逐步求精 答案:A [解析] 结构化程序设计的思想包括:自顶向下、逐步求精、模块化、限制使用goto语句,所以选择A。 3. 软件设计中模块划分应遵循的准则是______。 A 低内聚低耦合 B 高内聚低耦合

C 低内聚高耦合 D 高内聚高耦合 答案:B [解析] 软件设计中模块划分应遵循的准则是高内聚低偶合、模块大小规模适当、模块的依赖关系适当等。模块的划分应遵循一定的要求,以保证模块划分合理,并进一步保证以此为依据开发出的软件系统可靠性强,易于理解和维护。模块之间的耦合应尽可能的低,模块的内聚度应尽可能的高。 4. 在软件开发中,需求分析阶段产生的主要文档是______。 A 可行性分析报告 B 软件需求规格说明书 C 概要设计说明书 D 集成测试计划 答案:B [解析] A错误,可行性分析阶段产生可行性分析报告。C错误,概要设计说明书是总体设计阶段产生的文档。D错误,集成测试计划是在概要设计阶段编写的文档。B正确,需求规格说明书是后续工作如设计、编码等需要的重要参考文档。 5. 算法的有穷性是指______。 A 算法程序的运行时间是有限的 B 算法程序所处理的数据量是有限的 C 算法程序的长度是有限的 D 算法只能被有限的用户使用

相关主题
文本预览
相关文档 最新文档