一、選擇題(共30分,每小題2分)
1.在下面的函數聲明語句中,存在著語法錯誤的是( )。
單選題 (2 分) 2分
A.AA(int a, int b)
B.AA(int, int)
C.AA(int a; int b)
D.AA(int a, int)
2.在下面的保留字中,不能作為函數的返回值類型的是( )。
單選題 (2 分) 2分
A.void
B.int
C.enum
D.long
3.假定p是一個指向float型數據的指針,則p+1所指數據的地址比p所指數據的地址增加的字節(jié)數為( )。
單選題 (2 分) 2分
A.1
B.2
C.4
D.8
4.假定a為一個數組名,在下面的表達式中,存在語法錯誤的是( )。
單選題 (2 分) 2分
A.a[i]
B.*a++
C.*a
D.*(a+1
5.用calloc函數創(chuàng)建具有10個整型元素的一維數組的正確語句是( )。
單選題 (2 分) 2分
A.int *p=calloc(10,2);
B.int *p=calloc(10);
C.int *p=calloc(10,4);
D.int *p=malloc(10)
6.假定變量m定義為“int m=7;”,則下面正確的語句為( )。
單選題 (2 分) 2分
A.int p=&m;
B.int *p=&m;
C.int &p=*m;
D.int *p=m;
7.假定k是一個double類型的變量,則定義變量p的正確語句為( )。
單選題 (2 分) 2分
A.double p=&k;
B.int *p=&k;
C.double &p=*k;
D.char *p=”Thank you!”;
8.若有語句為“int a[10], x, *pa=a;”,要把數組a中下標為3的元素值賦給x,則不正確的語句為( )。
單選題 (2 分) 2分
A.x=pa[3];
B.x=*(a+3);
C.x=a[3];
D.x=*pa+3;
9.假定有語句為“int b[10]; int *pb;”,則下面不正確的賦值語句為( )。
單選題 (2 分) 2分
A.pb=b;
B.pb=&b[0];
C.pb=b+2;
D.pb=b[5];
10.已知“int *p=malloc(100);”,要釋放p所指向的動態(tài)內存,正確的語句為( )。
單選題 (2 分) 2分
A.free(p);
B.free p;
C.free(*p);
D.free[p];
11.在程序的一個文件中定義的函數,若要在另一個文件中調用,則必須在這另一個文件中給出該函數的( )。
單選題 (2 分) 2分
A.原型語句
B.參數表
C.函數名
D.返回類型
12.假定一個函數定義為“static int f1(int x,int y){return x+y;}”,該函數名稱為( )。
單選題 (2 分) 2分
A.static
B.int
C.f1
D.return
13.假定一個函數的原型語句為“int ff(int* x);”,一個整型數組為a[10],則下面函數調用表達式不正確的是( )。
單選題 (2 分) 2分
A.ff(a)
B.ff(a[0])
C.ff(a+3)
D.ff(&a[0])
14.假定一個函數的數組參數說明為char a[],與之等價的指針參數說明為( )。1B
單選題 (2 分) 2分
A.char a
B.char* a
C.char& a
D.char**a
15.假定一個函數的二維數組參數說明為char w[][N],與之等價的指針參數說明為( )。
單選題 (2 分) 2分
A.char (*w)[N]
B.char *w[N]
C.char (*w)N
D.char**a
二、判斷題(共30分,每小題2分。敘述正確則回答“是”,否則回答“否”)
16.在C語言中,一個函數由函數頭和函數體組成。
判斷題 (2 分) 2分
A.對
B.錯
17.在函數模塊之外定義的變量稱為全局變量,若沒有被初始化則系統(tǒng)隱含對它賦初值0。
判斷題 (2 分) 2分
A.對
B.錯
18.如果一個函數只允許同一程序文件中的函數調用,則不應在該函數定義的開始前加上保留字static。
判斷題 (2 分) 2分
A.對
B.錯
19.如果在一個函數體中又出現對自身函數的調用,此種函數調用被稱為遞歸調用。
判斷題 (2 分) 2分
A.對
B.錯
20.調用系統(tǒng)函數時,要先使用#include命令包含該系統(tǒng)函數的原型語句所在的系統(tǒng)頭文件。
判斷題 (2 分) 2分
A.對
B.錯
21.函數形參變量不屬于局部變量。
判斷題 (2 分) 2分
A.對
B.錯
22.假定p所指對象的值為25,p+1所指對象的值為46,則*p++的值為46。
判斷題 (2 分) 2分
A.對
B.錯
23.假定p所指對象的值為25,p+1所指對象的值為46,則*++p的值為25。
判斷題 (2 分) 2分
A.對
B.錯
24.假定p所指對象的值為25,p+1所指對象的值為46,則執(zhí)行*(p++)運算后,p所指對象的值為46。
判斷題 (2 分) 2分
A.對
B.錯
25.假定a是一個指針數組,則a+i所指對象的地址比a地址大4*i字節(jié)。
判斷題 (2 分) 2分
A.對
B.錯
26.若要把一個整型指針p轉換為字符指針,則采用的強制轉換表達式為(char*)p。
判斷題 (2 分) 2分
A.對
B.錯
27.假定一個數據對象為int*類型,則指向該對象的指針類型仍為int*類型。
判斷題 (2 分) 2分
A.對
B.錯
28.假定x為一個簡單變量,則&x表示x的地址。
判斷題 (2 分) 2分
A.對
B.錯
29.若p指向x,則*p與x的值不同。
判斷題 (2 分) 2分
A.對
B.錯
30.NULL是一個符號常量,通常作為空指針值,它代表的值為0。
判斷題 (2 分) 2分
A.對
B.錯
三、寫出下列每個程序運行后的輸出結果(共20分,每小題4分)
31.
31.
#include<stdio.h>
int WF(int x, int y) {
x=x+y;
y=x+y;
return x+y;
}
void main() {
int x=5, y=7;
int z=WF(x,y);
printf(“z=%d\n”,z);
}
簡答題 (4 分)
32.
#include<stdio.h>
#include<string.h>
void fun(char ss[]);
void main( ) {
char s[15]=”0123456789″;
fun(s);
printf(“%s\n”,s);
}
void fun(char ss[]) {
int i, n=strlen(ss) ;
for(i=0; i<n/2; i++) {
char c=ss[i];
ss[i]=ss[n-1-i];
ss[n-1-i]=c;
}
}
簡答題 (4 分)
33.
#include<stdio.h>
int Count(int a[], int n, int x)
{
int i,c=0;
for(i=0;i<n;i++)
if(a[i]>x) c++;
return c;
}
void main() {
int a[8]={20,15,32,47,24,36,28,70};
int b=Count(a,8,30);
printf(“b=%d\n”,b);
}
簡答題 (4 分)
34.
#include<stdio.h>
void main() {
int a[8]={3,5,7,9,2,3,4,8};
int s=0,*p;
for(p=a;p<a+8;) s+=*p++;
printf(“s=%d\n”,s);
}
簡答題 (4 分)
35.
#include<stdio.h>
int LA(int *a, int n, int x) {
int i,s=0;
for(i=0;i<n;i++)
if(a[i]<x) s+=a[i];
return s;
}
void main() {
int a[8]={5,10,15,8,12,3,9,20};
int b=LA(a,5,10);
int c=LA(a+2,6,10);
printf(“%d %d\n”,b,c);
}
簡答題 (4 分)
四、寫出下列每個函數的功能(共20分,每小題4分)
36.double SF(double x, int n) { //n為正整數
double p=1,s=1;
int i;
for(i=1;i<=n;i++) {
p*=x;
s+=p;
}
return s;
}
簡答題 (4 分)
37.
int SG(int x) { //x為大于等于2的整數
int i=2;
while(i*i<=x) {
if(x%i==0) break;
i++;
}
if(i*i<=x) return 0; else return 1;
}
簡答題 (4 分)
38.int WB(int a[], int n, int x) {
for(int i=0;i<n;i++)
if(a[i]==x) return 1;
return 0;
}
簡答題 (4 分)
39.
int fun(int m, int n) {
int c=0;
static int b=2;
if(m<b || n<b) return m*n;
else if(m%b==0 && n%b==0) {c=b; return c*fun(m/b,n/b);}
else {b++; return fun(m,n);}
}
簡答題 (4 分)
40.
int LK(double a[], int n) {
double s=0;
int i,m=0;
for(i=0;i<n;i++) s+=a[i];
s/=n;
for(i=0;i<n;i++)
if(a[i]>=s) m++;
return m;
}
簡答題 (4 分)
奧鵬,國開,廣開,電大在線,各省平臺,新疆一體化等平臺學習
詳情請咨詢QQ : 3230981406或微信:aopopenfd777