關于矩陣的唯美句子集合50條
計算機二級c語言試題
多花點時間看看書,然后做做題,計算機二級完全沒有問題。下面是計算機二級c語言試題,歡迎練習。
【第1句】:以下敘述中正確的是
A.只要適當地修改代碼,就可以將do-while與while相互轉換
B.對于“for(表達式1;表達式2;表達式3)循環體”首先要計算表達式2的值,以便決定是否開始循環
C.對于“for(表達式1;表達式2;表達式3)循環體”,只在個別情況下才能轉換成while語句
D.如果根據算法需要使用無限循環(即通常所稱的“死循環”),則只能使用while語句
參考答案:A
參考解析:B選項中,for語句中需要先求解先求解表達式1;C選項中,for語句使用最為靈活,它完全可以取代while語句;D選項中,對于死循環,也可以使用for語句。因此A選項正確。
【第2句】:以下敘述中正確的是
A.兩個字符串可以用關系運算符進行大小比較
B.函數調用strlen(s);會返回字符串S實際占用內存的大小(以字節為單位)
C.C語言本身沒有提供對字符串進行整體操作的運算符
D.當拼接兩個字符串時,結果字符串占用的內存空間是兩個原串占用空間的和
參考答案:C
參考解析:本題考查字符串處理函數strien、strcat、strcmp。B選項中strlen返回的是字符串s實際占用內存大小加上結尾符,A選項中不能用關系運算符進行大小比較,可以使用strcmp。D選項當使用連接函數strcat時,內存空間會減少一個字符位置。
【第3句】: 下列不正確的定義是( )。
A、int *p=&i,i;
B、int *p,i;
C.int i,*p=&i;
D、int i,*p;
參考答案:A
參考解析:選項A先定義一個整型指針變量p,然后將變量i的地址賦給p。然而此時還未定義變量i因此編譯器無法獲得變量i的地址。(A與C對比,選項C先定義變量i,則在內存中為i分配空間,因此i在內存空間的地址就可以確定了;然后再定義p,此時可以為p賦i的地址,C正確)
【第4句】:下列數據中屬于“字符串常量”的是( )。
A、“a”
B、{ABC}
C、‘abc\0’
D、‘a’
參考答案:A
參考解析:若干個字符構成字符串
在C語言中,用單引號標識字符;用雙引號標識字符串。選項B,C,分別用{}和’’標識字符串。選項D,標識字符。
【第5句】:已知char x[]="hello", y[]={'h','e','a','b','e'};, 則關于兩個數組長度的正確描述是 .
A、相同
B、x大于y
C、x小于y
D、以上答案都不對
參考答案:B
參考解析:can'kaoC語言中,字符串后面需要一個結束標志位'\0',通常系統會自動添加。
對一維數組初始化時可采用字符串的形式(例如本題數組x),也可采用字符集合的形式(例如本題數組y)。在以字符串形式初始化時,數組x不盡要存儲字符串中的字符,還要存儲字符串后的結束標志位,因此數組x的長度為6;在以字符集合形式初始化時,數組y,僅存儲集合中的元素,因此數組y長度為5
【第6句】:若有定義語句:char a='82';則變量a( )
A.說明不合法
B.包含1個字符
C.包含2個字符
D.包含3個字符
參考答案:B
參考解析:char a='82',定義字符量a,char型變量值為1個字節長度,并從右側開始運算,所以a的值應為'2'。因此B選項正確。
【第7句】: 以下敘述中正確的`是
A.對于邏輯表達式:a++|| b++,設a的值為1,則求解表達式的值后,b的值會發生改變
B.對于邏輯表達式:a++&&b++,設a的值為0,則求解表達式的值后。b的值會發生改變
C.else不是一條獨立的語句,它只是if語句的一部分
D.關系運算符的結果有三種:0,1,-1
參考答案:C
參考解析:B選項和A選項中,&&、||都是先計算左邊表達式的值,當左邊表達式的值能確定整個表達式的值。而且&&、||的優先級比++高,所以題中只需判斷a的值即可知道符合表達式的真假;D選項中,關系運算符的結果有“真”和“假”兩種。因此c選項正確。
【第8句】: 以下選項中合法的c語言常量是( )。
A.,C—STR’
B.20【第14句】:1
C.”l.0
D.2EK
參考答案:B
參考解析:所謂常量是指在程序運行的過程中,其值不能被改變的量。在C語言中,有整型常量、實型常量、字符常量和字符串常量等類型。選項A是字符串,但使用單引號,錯誤,選項c,D,為實型常量中指數形式,但指數形式e(E)之前必須是數字,之后必須為整數,錯誤。故答案為B選項。
【第9句】: 若“int n; float f=【第13句】:8;”,則執行“n=(int)f%3”后,n的值是( )
A、1
B、4
C、【第4句】:333333
D、【第4句】:6
參考答案:A
參考解析:“(int)f“表示將f中的值強制類型轉換為整型,即將【第13句】:8的小數部分舍掉,轉換為13;然后計算13%3,結果為1,再將結果賦給變量n,因此n的值為1
【第10句】:以下能對一維數組a進行初始化的語句是:( )
A、int a[5]=(0,1,2,3,4,)
B、 inta(5)={}
C、 int a[3]={0,1,2}
D、 int a{5}={10*1}
參考答案:C
參考解析:詳見教材P145,一維數組的定義、初始化
選項B,D,常量表達式只能放在中括號 [ ]中
選項A,數組可以看做是若干個相同數據類型元素的有序集合,因此以集合的形式對其初始化,使用{ }對其初始化,選項A用了().
計算機二級c語言試題及答案
計算機二級考試是全國計算機等級考試(National Computer Rank Examination,簡稱NCRE)四個等級中的一個等級,考核計算機基礎知識和使用一種高級計算機語言編寫程序以及上機調試的基本技能。計算機二級考試采用全國統一命題、統一考試的形式。那么計算機二級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)
【第8句】:下列四組字符串中都可以用作C語言程序中的標識符的是( A)。
A、print _3d db8 aBc
B、Iam 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%(-2)=1;(-5)%2=-1;(-5)%(-2)=-1;
/為求商運算符,該運算符能夠對整型、字符、浮點等類型的數據進行運算,5/2=2
【第11句】:如果int a=3,b=4;則條件表達式"aA、 3
B、 4
C、 0
D、1
詳見教材P【第97句】:
表達式1?表達式2:表達式3
先計算表達式1,
若表達式1成立, 則選擇計算表達式2,并表達式2的值作為整個大表達式的值;
若表達式1不成立,則選擇計算表達式3,并將表達式3的值作為整個大表達式的值
此題中的aa為3,b為4。a【第12句】:若int x=2,y=3,z=4 則表達式x
A、4
B、3
C、2
D、0
E)1
【第13句】:C語言中,關系表達式和邏輯表達式的值是( B ) 。
A、0
B、 0或1
C、 1
D、‘T’或’F’
【第14句】: 下面( D )表達式的值為【第4句】:
A、 11/3
B、 【第11句】:0/3
C、 (float)11/3
D、 (int)(【第11句】:0/3+0.5)
14~16題為同一類型
詳見教材P54~【第56句】:
(1)相同數據類型的元素進行數學運算(+、-、*、/)得到結果還保持原數據類型。
(2)不同數據類型的元素進行數學運算,先要統一數據類型,統一的標準是低精度類型轉換為高精度的數據類型。
選項A,11與3為兩個整數,11/3結果的數據類型也應為整數,因此將【第3句】:666666的小數部分全部舍掉,僅保留整數,因此11/3=【第3句】:
選項B,【第11句】:0為實數,3為整數,因此首先要統一數據類型,將整型數據3轉換為【第3句】:0,轉換后數據類型統一為實型數據,選項B變為【第11句】:0/【第3句】:0,結果的數據類型也應為實型數據,因此選項B 【第11句】:0/3=【第3句】:666666
選項C,先將整數11強制類型轉換,轉換為實型【第11句】:0,因此選項C變為【第11句】:0/3,其后計算過程、結果與選項B同
選項D,首先計算【第11句】:0/3,其計算過程、結果與選項B同,得到【第3句】:666666;再計算【第3句】:666666+0.5=【第4句】:166666,最后將【第4句】:166666強制類型轉換為整型,即將其小數部分全部舍掉,結果為4
【第15句】:設整型變量 a=2,則執行下列語句后,浮點型變量b的值不為0.5的是( B )
A、b=【第1句】:0/a
B、b=(float)(1/A、
C、b=1/(float)a
D、b=1/(a*【第1句】:0)
【第16句】: 若“int n; float f=【第13句】:8;”,則執行“n=(int)f%3”后,n的值是(A)
A、1
B、4
C、【第4句】:333333
D、【第4句】:6
“(int)f“表示將f中的值強制類型轉換為整型,即將【第13句】:8的小數部分舍掉,轉換為13;然后計算13%3,結果為1,再將結果賦給變量n,因此n的值為1
【第17句】: 以下對一維數組a的正確說明是: D
A、char a(10);
B、 int a[];
C、int k=5,a[k];
D、char a[3]={‘a’,’b’,’c’};
詳見教材P143~144,一維數組的定義、初始化
類型符 數組名 [常量表達式]
類型符是指數組中數組元素的類型;數組名要符合標識符命名規則;常量表達式是指數組的長度(數組中包含元素的個數),其值只能是整數,不可以是變量,而且從1開始計數。
選項A,常量表達式只能放在中括號 [ ]中
選項B,只有在對數組初始化(即賦值)的時候才可以省略數組的長度,B中并未對a進行初始化。
選項C,常量表達式不能為變量。
【第18句】:以下能對一維數組a進行初始化的語句是:( C )
A、int a[5]=(0,1,2,3,4,)
B、 inta(5)={}
C、 int a[3]={0,1,2}
D、 int a{5}={10*1}
詳見教材P145,一維數組的定義、初始化
選項B,D,常量表達式只能放在中括號 [ ]中
選項A,數組可以看做是若干個相同數據類型元素的有序集合,因此以集合的形式對其初始化,使用{ }對其初始化,選項A用了().
【第19句】:在C語言中對一維整型數組的正確定義為 D 。
A、int a(10);
B、int n=10,a[n];
C、int n;a[n];
D、#define N 10
int a[N];
【第20句】:已知:int a[10]; 則對a數組元素的正確引用是( D )。
A、a[10]
B、a[【第3句】:5]
C、a(5)
D、a[0]
詳見教材P144,數組元素的引用
數組名[下標]
引用數組元素時,[ ]中的下標為邏輯地址下標,只能為整數,可以為變量,且從0開始計數
int a[10]表示定義了一個包含10個整型數據的數組a,數組元素的邏輯地址下標范圍為0~9,即a[0] 表示組中第1個元素; a[1] 表示組中第2個元素; a[2] 表示組中第3個元素; ......;a[9] 表示組中第10個元素.
選項A,超過了數組a的'邏輯地址下標范圍;
選項B,邏輯地址下標只能為整數
選項C,邏輯地址下標只能放在[ ]中
【第21句】:若有以下數組說明,則i=10;a[a[i]]元素數值是(C )。
int a[12]={1,4,7,10,2,5,8,11,3,6,9,12};
A、10
B、9
C、6
D、5
先算a[a[i]]內層的a[i],由于i=10,因此a[i]即a[10].
a[10]對應下面數組中的元素為【第9句】: 因此a[a[i]]即為a[9]
a[9]對應下面數組中的元素為【第6句】: 因此a[9]即為6
【第22句】:若有說明:int a[][3]={{1,2,3},{4,5},{6,7}}; 則數組a的第一維的大小為: ( B )
A、2
B、3
C、4
D、無確定值
5 7
D、3 6 9
二維數組的一維大小,即指二維數組的行數,在本題中,按行對二維數組賦值,因此內層有幾個大括號,數組就有幾行
【第23句】:對二維數組的正確定義是(C )
詳見教材P149~152,二維數組的定義、初始化
類型符 數組名 [常量表達式][常量表達式]
二維數組可以看做是矩陣
類型符是指數組中數組元素的類型;數組名要符合標識符命名規則;第一個常量表達式是指數組的行數;第二個常量表達式是指數組的列數;常量表達式的值只能是整數,不可以是變量,而且從1開始計數。
一維數組初始化時可以省略數組長度
二維數組初始化時可以省略行數,但不能省略列數
選項A,B,都省略了列數
選項D,不符合二維數組定義的一般形式,行、列常量表達式應該放在不同的[]中
A、int a[ ][ ]={1,2,3,4,5,6};
B、int a[2] []={1,2,3,4,5,6};
C、int a[ ] [3]={1,2,3,4,5,6};
D、int a[2,3]={1,2,3,4,5,6};
【第24句】:已知int a[3][4];則對數組元素引用正確的是__C___
A、a[2][4]
B、a[1,3]
C、a[2][0]
D、a(2)(1)
詳見教材P150,數組元素的引用
數組名[下標] [下標]
引用數組元素時,[ ]中的下標為邏輯地址下標,只能為整數,可以為變量,且從0開始計數
第一個[下標]表示行邏輯地址下標,第二個[下標]表示列邏輯地址下標。
本題圖示詳見P149圖【第6句】:7
因此a的行邏輯地址范圍0~2;a的列邏輯地址范圍0~3;
選項A,列邏輯地址下標超過范圍
選項B,D,的引用形式不正確。
【第25句】:C語言中函數返回值的類型是由 A 決定的.
A、函數定義時指定的類型
B、 return語句中的表達式類型
C、 調用該函數時的實參的數據類型
D、形參的數據類型
【第26句】: 在C語言中,函數的數據類型是指(A )
A、 函數返回值的數據類型
B、 函數形參的數據類型
C、 調用該函數時的實參的數據類型
D、任意指定的數據類型
【第27句】:在函數調用時,以下說法正確的是( B )
A、函數調用后必須帶回返回值
B、實際參數和形式參數可以同名
C、函數間的數據傳遞不可以使用全局變量
D、主調函數和被調函數總是在同一個文件里
【第28句】: 在C語言中,表示靜態存儲類別的關鍵字是: ( C )
A、 auto
B、 register
C、static
D、extern
【第29句】:未指定存儲類別的變量,其隱含的存儲類別為(A )。
A、auto
B、static
C、extern
D、register
【第30句】: 若有以下說明語句:
struct student
{ int num;
char name[ ];
float score;
}stu;
則下面的敘述不正確的是: (D )
A、 struct是結構體類型的關鍵字
B、 struct student 是用戶定義的結構體類型
C、 num, score都是結構體成員名
D、 stu是用戶定義的結構體類型名
【第31句】:若有以下說明語句:
struct date
{ int year;
int month;
int day;
}brithday;
則下面的敘述不正確的是__C___.
A、 struct是聲明結構體類型時用的關鍵字
B、 struct date 是用戶定義的結構體類型名
C、 brithday是用戶定義的結構體類型名
D、year,day 都是結構體成員名
【第32句】: 以下對結構變量stul中成員age的非法引用是 B
struct student
{ int age;
int num;
}stu1,*p;
p=&stu1;
A、 stu【第1句】:age
B、 student.age
C、 p->age
D、(*p).age
【第33句】:設有如下定義:
struck sk
{ int a;
float b;
}data;
int *p;
若要使P指向data中的a域,正確的賦值語句是 C
A、 p=&a;
B、 p=datA、a;
C、p=&datA、a;
D、*p=datA、a;
【第34句】:設有以下說明語句:
typedef struct stu
{ int a;
float b;
} stutype;
則下面敘述中錯誤的是( D )。
A、struct是結構類型的關鍵字
B、struct stu是用戶定義的結構類型
C、a和b都是結構成員名
D、stutype是用戶定義的結構體變量名
【第35句】:語句int *p;說明了 C 。
A、p是指向一維數組的指針
B、p是指向函數的指針,該函數返回一int型數據
C、p是指向int型數據的指針 // 指針的定義教材P223
D、p是函數名,該函數返回一指向int型數據的指針
【第36句】:下列不正確的定義是( A )。
A、int *p=&i,i;
B、int *p,i;
C.int i,*p=&i;
D、int i,*p;
選項A先定義一個整型指針變量p,然后將變量i的地址賦給p。然而此時還未定義變量i因此編譯器無法獲得變量i的地址。(A與C對比,選項C先定義變量i,則在內存中為i分配空間,因此i在內存空間的地址就可以確定了;然后再定義p,此時可以為p賦i的地址,C正確)
【第37句】: 若有說明:int n=2,*p=&n,*q=p,則以下非法的賦值語句是: ( D )
A、p=q
B、*p=*q
C、n=*q
D、p=n
p,q同為整型指針變量,二者里面僅能存放整型變量的地址。
選項A,q中為地址,因此可將此地址賦給p
選項B,*p表示p所指向對象n的內容,即一個整數;*q表示q所指向對象的內容,由于在定義q時為其初始化,將p中n的地址給q,因此p中存放n的地址,*q表示q所指向對象n的內容.因此*p=*q 相當于 n=n;
選項C,n=*q 等價于n=n;
選項D,p中只能存放地址,不能將n中的整數值賦給p
【第38句】:有語句:int a[10],;則 B 是對指針變量p的正確定義和初始化。
A、int p=*a;
B、int *p=a;
C、int p=&a;
D、int *p=&a;
選項A,a是數組名,不是指針變量名,因此不可用*標注數組名a
選項C,a是數組名,數組名就是地址,無需再用地址符號。而且在定義指針變量p時,應在變量名前加*,標明p是指針變量
選項D,a是數組名,數組名就是地址,無需再用地址符號。
【第39句】:若有說明語句“int a[5],*p=a;”,則對數組元素的正確引用是( C )。
A、a[p]
B、p[a]
C、*(p+2)
D、p+2
首先定義一個整型數組a,a的長度為5,然后定義一個指針變量p,并同時對p進行初始化,將數組a的地址賦給p。因此此時p中存放的數組a的首地址,即數組中第一個元素a[0]的地址。
對于數組元素下標的引用(詳見p144), 一般形式 數組名[下標] 其中下標為邏輯地址下標,從0開始計數,方括號中的下標可以是變量,可以是表達式,但結果一定要是整數。
選項A,p中存放的是地址,不是整數,不能做數組元素的下標
選項B,a是數組名,數組名就是地址,不是整數,不能做數組元素的下標
選項C,(重點!!!詳見p231~234) p+2表示指向同一數組中的下兩個元素的地址,當前p指向a[0],則p+2表示a[2]的地址,因此*(p+2)表示a[2]的內容
【第40句】: 有如下程序
int a[10]={1,2,3,4,5,6,7,8,9,10},*P=a;
則數值為9的表達式是 B
A、 *P+9
B、 *(P+8)
C、 *P+=9
D、P+8
(重點!!!詳見p231~234)
首先定義一個整型數組a,a的長度為5,然后定義一個指針變量P,并同時對P進行初始化,將數組a的地址賦給P。因此此時P中存放的數組a的首地址,即數組中第一個元素a[0]的地址。
數組中9對應的是a[8], 選項B,P+8表示數組中后8個元素的地址,即a[8]的地址。*(P+8)則表示該地址內所存放的內容,即a[8]的值。
選項A,*P表示P所指向對象的內容,此時P指向a[0], *P即a[0]的值【第1句】: *P+9=1+9=10
選項C,*P表示P所指向對象的內容,此時P指向a[0], *P即a[0]的值。因此*P+=9 即*P =*P+9, 等價于a[0]=a[0]+【第9句】:
選項D,P+8表示數組中后8個元素的地址,即a[8]的地址,而非a[8]中的值。
計算機c語言試題及答案
【第1句】:
#include "stdio.h"
main()
{char c;
c=get);
while(c!='?') {putc);c=get); }
}
如果從鍵盤輸入abcde?fgh(回車)
運行結果為:abcde
【第2句】:
#include
main()
{ char c;
while((c=get))!=’$’)
{ if(‘A’<=c&&c<=‘Z’)putc);
else if(‘a’<=c&&c<=‘z’)putc-32);}
}
當輸入為ab*AB%cd#CD$時,運行結果為:ABABCDCD
【第3句】:
#include
main()
{ int x, y =0;
for(x=1;x<=10;x++)
{ if(y>=10)
break;
y=y+x;
}
printf(“%d %d”,y,x);
}
運行結果為:10 5
詳見教材p120for語句
詳見教材p126~128break,continue語句
for( 表達式1;表達式2;表達式3)
{
}
(1) 先求解表達式1
(2) 求解表達式2,若其值為真,執行循環體,然后執行 (3). 若為假,則結束循環,轉到(5)
(3) 求解表達式3
(4) 轉回上面 (2)繼續執行
(5) 循環結束,執行for語句下面的一個語句
break ,跳出循環體;continue,結束本次循環(第i次循環),繼續執行下一次循環(第i+1次循環)
此題 表達式1為x=1,表達式2(循環條件)為x<=10,表達式3為x++
初值x為1,y為0,循環條件(即表達式2)x<=10成立,進入循環體
第1次循環
執行if語句。0小于10,if語句的條件表達式不成立,不執行break;
執行y=y+x; y=0+1=1
轉向表達式3,執行x++,x=x+1=1+1=2。循環條件x<=10成立,進入第2次循環
第2次循環
執行if語句。1小于10,if語句的條件表達式不成立,不執行break;
執行y=y+x; y=1+2=3
轉向表達式3,執行x++,x=x+1=2+1=3。循環條件x<=10成立,進入第3次循環
第3次循環
執行if語句。3小于10,if語句的條件表達式不成立,不執行break;
執行y=y+x; y=3+3=6
轉向表達式3,執行x++,x=x+1=3+1=4。循環條件x<=10成立,進入第4次循環
第4次循環
執行if語句。6小于10,if語句的條件表達式不成立,不執行break;
執行y=y+x; y=6+4=10
轉向表達式3,執行x++,x=x+1=4+1=5。循環條件x<=10成立,進入第5次循環
第5次循環
執行if語句。10等于10,if語句的條件表達式成立,執行break,跳出循環。
從break跳出至for語句的下一條語句。執行printf(“%d %d”,y,x);
輸出當前的y與x.結果為10 5
【第4句】:
#include
main( )
{char ch;
ch=get );
switch(ch)
{case‘A’ : printf(“%c”,’A’);
case‘B’ : printf(“%c”,’B’); break;
default: printf(“%s”,”other”);
} }
當從鍵盤輸入字母A時,運行結果為:AB
詳見教材p103,switch語句
switch(表達式)
{ case常量1 :語句1
case常量2 :語句2
┇┇ ┇
case常量n :語句n
default :語句n+1
}
其中表達式,常量1,…,常量n都為整型或字符型
case相當于給出執行程序的入口和起始位置,若找到匹配的常量,則從此處開始往下執行程序,不再匹配常量,直至遇到break或switch結束
本題過程:
首先從鍵盤接收一個字符’A’并將其放在變量ch中。
執行switch語句。Switch后面的條件表達式為ch,因此表達式的值即為字符’A’. 用字符’A’依次與下面的 case中的常量匹配。
與第1個case后的常量匹配,則從其后的語句開始往下執行程序(在執行過程中不再進行匹配。)因此先執行printf(“%c”,’A’),屏幕上輸出A;再往下繼續執行printf(“%c”,’B’),屏幕上輸出B;再繼續執行break, 此時跳出switch語句。
【第5句】:
#include
main( )
{ int a=1,b=0;
scanf(“%d”,&a);
switch(a)
{case 1: b=1;break;
case 2: b=2;break;
default : b=10;}
printf("%d ", b);
}
若鍵盤輸入5,運行結果為:10
本題過程:
首先用scanf函數為變量a賦值為5。
執行switch語句。switch后面的條件表達式為a,因此表達式的值即為【第5句】: 用5依次與下面 case中的常量匹配。沒有找到匹配的常量,因此兩個case后的語句都不執行。執行default后面的語句b=10;將10賦給變量b。
輸出變量b,結果為10
【第6句】:
#include
main()_
{ char grade=’C’;
switch(grade)
{
case ‘A’: printf(“90-100”);
case ‘B’: printf(“80-90”);
case ‘C’: printf(“70-80”);
case ‘D’: printf(“60-70”); break;
case ‘E’: printf(“<60”);
default : printf(“error!”);
}
}
運行結果為:
70-80
60-70
本題過程:
首先從鍵盤接收一個字符’C’并將其放在變量grade中。
執行switch語句。switch后面的條件表達式為grade,因此表達式的.值即為字符’C’. 用字符’C’依次與下面的 case中的常量匹配。
與第3個case后的常量匹配,則從其后的語句開始往下執行程序(在執行過程中不再進行匹配。)因此先執行printf(“70-80”);,屏幕上輸出70-80,并換行;再往下繼續執行printf(“60-70”),屏幕上輸出60-70,并換行;再繼續執行break, 此時跳出switch語句。
【第7句】:
#include
main()
{ int y=9;
for(;y>0;y- -)
if(y%3==0)
{ printf(%d”,- -y);
}
}
運行結果為:
852
詳見教材p53,自增自減符號
此題 表達式1被省略,表達式2(循環條件)為y>0,表達式3為y--
初值y為9,循環條件(即表達式2)y>0成立,進入循環體
第1次循環
執行if語句。9%3==0,if語句的條件表達式成立,執行printf(%d”,- -y),即y先自減1變為8,然后在輸出,因此屏幕上輸出8
轉向表達式3,執行y--,y=y-1=8-1=7。循環條件y>0成立,進入第2次循環
第2次循環
執行if語句。7%3不為0,if語句的條件表達式不成立,不執行printf(%d”,- -y)
轉向表達式3,執行y--,y=y-1=7-1=6。循環條件y>0成立,進入第3次循環
第3次循環
執行if語句。6%3==0,if語句的條件表達式成立,執行printf(%d”,- -y),即y先自減1變為5,然后在輸出,因此屏幕上輸出5
轉向表達式3,執行y--,y=y-1=5-1=4。循環條件y>0成立,進入第4次循環
第4次循環
執行if語句。4%3不為0,if語句的條件表達式不成立,不執行printf(%d”,- -y)
轉向表達式3,執行y--,y=4-1=3。循環條件y>0成立,進入第5次循環
第5次循環
執行if語句。3%3==0,if語句的條件表達式成立,執行printf(%d”,- -y),即y先自減1變為2,然后在輸出,因此屏幕上輸出2
轉向表達式3,執行y--,y=y-1=2-1=1。循環條件y>0成立,進入第5次循環
第6次循環
執行if語句。1%3不為0,if語句的條件表達式不成立,不執行printf(%d”,- -y)
轉向表達式3,執行y--,y=1-1=0。循環條件y>0不成立,循環結束。
【第8句】:
#include
main()
{ int i,sum=0;i=1;
do{ sum=sum+i; i++; }while(i<=10);
printf(“%d”,sum);
}
運行結果為: 55
【第9句】:
#include
#define N 4
main()
{ int i;
int x1=1,x2=2;
printf("");
for(i=1;i<=N;i++)
{ printf("%4d%4d",x1,x2);
if(i%2==0)
printf("");
x1=x1+x2;
x2=x2+x1;
}
}
運行結果為:
1 2 3 5
8 132134
此題 首先為整型變量賦初值x1=1,x2=2
表達式1為i=1,表達式2(循環條件)為i<=N即i<=4,表達式3為i++
循環變量初值i為1,循環條件(即表達式2)i<=4成立,進入第1次循環
第1次循環
執行printf("%4d%4d",x1,x2);因此屏幕上輸出12
執行if語句。1%2不為0,if語句的條件表達式不成立,不執行printf("");
執行x1=x1+x2=1+2=3;此時x1中的值已變為3
執行x2=x2+x1=2+3=5。
轉向表達式3,執行i++,i為2。循環條件i<=4成立,進入第2次循環
第2次循環
執行printf("%4d%4d",x1,x2);因此屏幕上輸出35
執行if語句。2%2==0,if語句的條件表達式成立,執行printf("");換行
執行x1=x1+x2=3+5=8;此時x1中的值已變為8
執行x2=x2+x1=5+8=13。
轉向表達式3,執行i++,i為3。循環條件i<=4成立,進入第3次循環
第3次循環
執行printf("%4d%4d",x1,x2);因此屏幕上輸出813
執行if語句。3%2不為0,if語句的條件表達式不成立,不執行printf("");
執行x1=x1+x2=8+13=21;此時x1中的值已變為21
執行x2=x2+x1=21+13=34。
轉向表達式3,執行i++,i為4。循環條件i<=4成立,進入第4次循環
第2次循環
執行printf("%4d%4d",x1,x2);因此屏幕上輸出2134
執行if語句。4%2==0,if語句的條件表達式成立,執行printf("");換行
執行x1=x1+x2=21+34=55;此時x1中的值已變為55
執行x2=x2+x1=34+55=89。
轉向表達式3,執行i++,i為5。循環條件i<=4不成立,結束循環
10
#include
main( )
{intx, y;
for(x=30, y=0; x>=10, y<10; x--, y++)
x/=2, y+=2;
printf(“x=%d,y=%d”,x,y);
}
運行結果為:
x=0,y=12 【第11句】:
#include
#define N 4
main( )
{ inti,j;
for(i=1;i<=N;i++)
{ for(j=1;j printf(" ");
printf("*");
printf("");
}}
運行結果為:
*
*
*
*
詳見教材P41符號常量
用宏處理指令定義符號常量N為4,在編譯過程中,遇到N即視為整數4。
外層for循環,表達式1為i=1,表達式2(循環條件)為i<=N,表達式3為 i++
內層for循環,表達式1為j=1,表達式2(循環條件)為j 首先計算外層循環的表達式1,i為1,使得循環條件i<=4成立,進入外層for循環體
外層for循環第1次此時i為1
內層循環j=1,使得循環條件j 執行printf("*");
執行printf("");換行
至此外層循環體執行完,計算外層循環的表達式3,i++,此時i為【第2句】: 使得循環條件i<=4
成立,再次進入外層for循環體
外層for循環第2次 此時i為2
內層循環j=1,使得循環條件j 第1次執行內層循環體printf(" ");
執行內層循環表達式3,j++為2,j 執行printf("*");
執行printf("");換行
至此外層循環體執行完,計算外層循環的表達式3,i++,此時i為【第3句】: 使得循環條件i<=4
成立,進入外層for循環體
外層for循環第3次 此時i為3
內層循環j=1,使得循環條件j 第1次執行內層循環體printf(" ");
執行內層循環表達式3,j++為2,j 第2次執行內層循環體printf(" ");
執行內層循環表達式3,j++為3,j 執行printf("*");
執行printf("");換行
至此外層循環體執行完,計算外層循環的表達式3,i++,此時i為【第4句】: 使得循環條件i<=4
成立,進入外層for循環體
外層for循環第4次 此時i為4
內層循環j=1,使得循環條件j 第1次執行內層循環體printf(" ");
執行內層循環表達式3,j++為2,j 第2次執行內層循環體printf(" ");
執行內層循環表達式3,j++為3,j 第3次執行內層循環體printf(" ");
執行內層循環表達式3,j++為4,j 執行printf("*");
執行printf("");換行
至此外層循環體執行完,計算外層循環的表達式3,i++,此時i為【第5句】: 使得循環條件i<=4
不成立,跳出外層for循環體
計算機二級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)
【第8句】:下列四組字符串中都可以用作C語言程序中的標識符的是( A)。
A、print _3d db8 aBc
B、Iam 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%(-2)=1;(-5)%2=-1;(-5)%(-2)=-1;
/為求商運算符,該運算符能夠對整型、字符、浮點等類型的數據進行運算,5/2=2
【第11句】:如果int a=3,b=4;則條件表達式"aA、 3
B、 4
C、 0
D、1
詳見教材P【第97句】:
表達式1?表達式2:表達式3
先計算表達式1,
若表達式1成立, 則選擇計算表達式2,并表達式2的值作為整個大表達式的值;
若表達式1不成立,則選擇計算表達式3,并將表達式3的值作為整個大表達式的值
此題中的aa為3,b為4。a【第12句】:若int x=2,y=3,z=4 則表達式x
A、4
B、3
C、2
D、0
E)1
【第13句】:C語言中,關系表達式和邏輯表達式的值是( B ) 。
A、0
B、 0或1
C、 1
D、‘T’或’F’
【第14句】: 下面( D )表達式的值為【第4句】:
A、 11/3
B、 【第11句】:0/3
C、 (float)11/3
D、 (int)(【第11句】:0/3+0.5)
14~16題為同一類型
詳見教材P54~【第56句】:
(1)相同數據類型的元素進行數學運算(+、-、*、/)得到結果還保持原數據類型。
(2)不同數據類型的元素進行數學運算,先要統一數據類型,統一的標準是低精度類型轉換為高精度的數據類型。
選項A,11與3為兩個整數,11/3結果的數據類型也應為整數,因此將【第3句】:666666的小數部分全部舍掉,僅保留整數,因此11/3=【第3句】:
選項B,【第11句】:0為實數,3為整數,因此首先要統一數據類型,將整型數據3轉換為【第3句】:0,轉換后數據類型統一為實型數據,選項B變為【第11句】:0/【第3句】:0,結果的數據類型也應為實型數據,因此選項B 【第11句】:0/3=【第3句】:666666
選項C,先將整數11強制類型轉換,轉換為實型【第11句】:0,因此選項C變為【第11句】:0/3,其后計算過程、結果與選項B同
選項D,首先計算【第11句】:0/3,其計算過程、結果與選項B同,得到【第3句】:666666;再計算【第3句】:666666+0.5=【第4句】:166666,最后將【第4句】:166666強制類型轉換為整型,即將其小數部分全部舍掉,結果為4
【第15句】:設整型變量 a=2,則執行下列語句后,浮點型變量b的值不為0.5的是( B )
A、b=【第1句】:0/a
B、b=(float)(1/A、
C、b=1/(float)a
D、b=1/(a*【第1句】:0)
【第16句】: 若“int n; float f=【第13句】:8;”,則執行“n=(int)f%3”后,n的值是(A)
A、1
B、4
C、【第4句】:333333
D、【第4句】:6
“(int)f“表示將f中的值強制類型轉換為整型,即將【第13句】:8的小數部分舍掉,轉換為13;然后計算13%3,結果為1,再將結果賦給變量n,因此n的值為1
【第17句】: 以下對一維數組a的正確說明是: D
A、char a(10);
B、 int a[];
C、int k=5,a[k];
D、char a[3]={‘a’,’b’,’c’};
詳見教材P143~144,一維數組的定義、初始化
類型符 數組名 [常量表達式]
類型符是指數組中數組元素的類型;數組名要符合標識符命名規則;常量表達式是指數組的長度(數組中包含元素的個數),其值只能是整數,不可以是變量,而且從1開始計數。
選項A,常量表達式只能放在中括號 [ ]中
選項B,只有在對數組初始化(即賦值)的時候才可以省略數組的長度,B中并未對a進行初始化。
選項C,常量表達式不能為變量。
【第18句】:以下能對一維數組a進行初始化的語句是:( C )
A、int a[5]=(0,1,2,3,4,)
B、 inta(5)={}
C、 int a[3]={0,1,2}
D、 int a{5}={10*1}
詳見教材P145,一維數組的定義、初始化
選項B,D,常量表達式只能放在中括號 [ ]中
選項A,數組可以看做是若干個相同數據類型元素的有序集合,因此以集合的形式對其初始化,使用{ }對其初始化,選項A用了().
【第19句】:在C語言中對一維整型數組的正確定義為 D 。
A、int a(10);
B、int n=10,a[n];
C、int n;a[n];
D、#define N 10
int a[N];
【第20句】:已知:int a[10]; 則對a數組元素的正確引用是( D )。
A、a[10]
B、a[【第3句】:5]
C、a(5)
D、a[0]
詳見教材P144,數組元素的引用
數組名[下標]
引用數組元素時,[ ]中的下標為邏輯地址下標,只能為整數,可以為變量,且從0開始計數
int a[10]表示定義了一個包含10個整型數據的數組a,數組元素的邏輯地址下標范圍為0~9,即a[0] 表示組中第1個元素; a[1] 表示組中第2個元素; a[2] 表示組中第3個元素; ......;a[9] 表示組中第10個元素.
選項A,超過了數組a的邏輯地址下標范圍;
選項B,邏輯地址下標只能為整數
選項C,邏輯地址下標只能放在[ ]中
【第21句】:若有以下數組說明,則i=10;a[a[i]]元素數值是(C )。
int a[12]={1,4,7,10,2,5,8,11,3,6,9,12};
A、10
B、9
C、6
D、5
先算a[a[i]]內層的a[i],由于i=10,因此a[i]即a[10].
a[10]對應下面數組中的元素為【第9句】: 因此a[a[i]]即為a[9]
a[9]對應下面數組中的元素為【第6句】: 因此a[9]即為6
【第22句】:若有說明:int a[][3]={{1,2,3},{4,5},{6,7}}; 則數組a的第一維的大小為: ( B )
A、2
B、3
C、4
D、無確定值
5 7
D、3 6 9
二維數組的一維大小,即指二維數組的行數,在本題中,按行對二維數組賦值,因此內層有幾個大括號,數組就有幾行
【第23句】:對二維數組的正確定義是(C )
詳見教材P149~152,二維數組的定義、初始化
類型符 數組名 [常量表達式][常量表達式]
二維數組可以看做是矩陣
類型符是指數組中數組元素的類型;數組名要符合標識符命名規則;第一個常量表達式是指數組的行數;第二個常量表達式是指數組的列數;常量表達式的值只能是整數,不可以是變量,而且從1開始計數。
一維數組初始化時可以省略數組長度
二維數組初始化時可以省略行數,但不能省略列數
選項A,B,都省略了列數
選項D,不符合二維數組定義的一般形式,行、列常量表達式應該放在不同的[]中
A、int a[ ][ ]={1,2,3,4,5,6};
B、int a[2] []={1,2,3,4,5,6};
C、int a[ ] [3]={1,2,3,4,5,6};
D、int a[2,3]={1,2,3,4,5,6};
【第24句】:已知int a[3][4];則對數組元素引用正確的是__C___
A、a[2][4]
B、a[1,3]
C、a[2][0]
D、a(2)(1)
詳見教材P150,數組元素的引用
數組名[下標] [下標]
引用數組元素時,[ ]中的下標為邏輯地址下標,只能為整數,可以為變量,且從0開始計數
第一個[下標]表示行邏輯地址下標,第二個[下標]表示列邏輯地址下標。
本題圖示詳見P149圖【第6句】:7
因此a的行邏輯地址范圍0~2;a的列邏輯地址范圍0~3;
選項A,列邏輯地址下標超過范圍
選項B,D,的引用形式不正確。
【第25句】:C語言中函數返回值的類型是由 A 決定的.
A、函數定義時指定的類型
B、 return語句中的表達式類型
C、 調用該函數時的實參的數據類型
D、形參的數據類型
【第26句】: 在C語言中,函數的數據類型是指(A )
A、 函數返回值的數據類型
B、 函數形參的數據類型
C、 調用該函數時的實參的數據類型
D、任意指定的數據類型
【第27句】:在函數調用時,以下說法正確的是( B )
A、函數調用后必須帶回返回值
B、實際參數和形式參數可以同名
C、函數間的數據傳遞不可以使用全局變量
D、主調函數和被調函數總是在同一個文件里
【第28句】: 在C語言中,表示靜態存儲類別的關鍵字是: ( C )
A、 auto
B、 register
C、static
D、extern
【第29句】:未指定存儲類別的變量,其隱含的存儲類別為(A )。
A、auto
B、static
C、extern
D、register
【第30句】: 若有以下說明語句:
struct student
{ int num;
char name[ ];
float score;
}stu;
則下面的敘述不正確的是: (D )
A、 struct是結構體類型的關鍵字
B、 struct student 是用戶定義的結構體類型
C、 num, score都是結構體成員名
D、 stu是用戶定義的結構體類型名
【第31句】:若有以下說明語句:
struct date
{ int year;
int month;
int day;
}brithday;
則下面的.敘述不正確的是__C___.
A、 struct是聲明結構體類型時用的關鍵字
B、 struct date 是用戶定義的結構體類型名
C、 brithday是用戶定義的結構體類型名
D、year,day 都是結構體成員名
【第32句】: 以下對結構變量stul中成員age的非法引用是 B
struct student
{ int age;
int num;
}stu1,*p;
p=&stu1;
A、 stu【第1句】:age
B、 student.age
C、 p->age
D、(*p).age
【第33句】:設有如下定義:
struck sk
{ int a;
float b;
}data;
int *p;
若要使P指向data中的a域,正確的賦值語句是 C
A、 p=&a;
B、 p=datA、a;
C、p=&datA、a;
D、*p=datA、a;
【第34句】:設有以下說明語句:
typedef struct stu
{ int a;
float b;
} stutype;
則下面敘述中錯誤的是( D )。
A、struct是結構類型的關鍵字
B、struct stu是用戶定義的結構類型
C、a和b都是結構成員名
D、stutype是用戶定義的結構體變量名
【第35句】:語句int *p;說明了 C 。
A、p是指向一維數組的指針
B、p是指向函數的指針,該函數返回一int型數據
C、p是指向int型數據的指針 // 指針的定義教材P223
D、p是函數名,該函數返回一指向int型數據的指針
【第36句】:下列不正確的定義是( A )。
A、int *p=&i,i;
B、int *p,i;
C.int i,*p=&i;
D、int i,*p;
選項A先定義一個整型指針變量p,然后將變量i的地址賦給p。然而此時還未定義變量i因此編譯器無法獲得變量i的地址。(A與C對比,選項C先定義變量i,則在內存中為i分配空間,因此i在內存空間的地址就可以確定了;然后再定義p,此時可以為p賦i的地址,C正確)
【第37句】: 若有說明:int n=2,*p=&n,*q=p,則以下非法的賦值語句是: ( D )
A、p=q
B、*p=*q
C、n=*q
D、p=n
p,q同為整型指針變量,二者里面僅能存放整型變量的地址。
選項A,q中為地址,因此可將此地址賦給p
選項B,*p表示p所指向對象n的內容,即一個整數;*q表示q所指向對象的內容,由于在定義q時為其初始化,將p中n的地址給q,因此p中存放n的地址,*q表示q所指向對象n的內容.因此*p=*q 相當于 n=n;
選項C,n=*q 等價于n=n;
選項D,p中只能存放地址,不能將n中的整數值賦給p
【第38句】:有語句:int a[10],;則 B 是對指針變量p的正確定義和初始化。
A、int p=*a;
B、int *p=a;
C、int p=&a;
D、int *p=&a;
選項A,a是數組名,不是指針變量名,因此不可用*標注數組名a
選項C,a是數組名,數組名就是地址,無需再用地址符號。而且在定義指針變量p時,應在變量名前加*,標明p是指針變量
選項D,a是數組名,數組名就是地址,無需再用地址符號。
【第39句】:若有說明語句“int a[5],*p=a;”,則對數組元素的正確引用是( C )。
A、a[p]
B、p[a]
C、*(p+2)
D、p+2
首先定義一個整型數組a,a的長度為5,然后定義一個指針變量p,并同時對p進行初始化,將數組a的地址賦給p。因此此時p中存放的數組a的首地址,即數組中第一個元素a[0]的地址。
對于數組元素下標的引用(詳見p144), 一般形式 數組名[下標] 其中下標為邏輯地址下標,從0開始計數,方括號中的下標可以是變量,可以是表達式,但結果一定要是整數。
選項A,p中存放的是地址,不是整數,不能做數組元素的下標
選項B,a是數組名,數組名就是地址,不是整數,不能做數組元素的下標
選項C,(重點!!!詳見p231~234) p+2表示指向同一數組中的下兩個元素的地址,當前p指向a[0],則p+2表示a[2]的地址,因此*(p+2)表示a[2]的內容
【第40句】: 有如下程序
int a[10]={1,2,3,4,5,6,7,8,9,10},*P=a;
則數值為9的表達式是 B
A、 *P+9
B、 *(P+8)
C、 *P+=9
D、P+8
(重點!!!詳見p231~234)
首先定義一個整型數組a,a的長度為5,然后定義一個指針變量P,并同時對P進行初始化,將數組a的地址賦給P。因此此時P中存放的數組a的首地址,即數組中第一個元素a[0]的地址。
數組中9對應的是a[8], 選項B,P+8表示數組中后8個元素的地址,即a[8]的地址。*(P+8)則表示該地址內所存放的內容,即a[8]的值。
選項A,*P表示P所指向對象的內容,此時P指向a[0], *P即a[0]的值【第1句】: *P+9=1+9=10
選項C,*P表示P所指向對象的內容,此時P指向a[0], *P即a[0]的值。因此*P+=9 即*P =*P+9, 等價于a[0]=a[0]+【第9句】:
選項D,P+8表示數組中后8個元素的地址,即a[8]的地址,而非a[8]中的值。
【第41句】: 在C語言中,以 D 作為字符串結束標志
A、’’
B、’ ’
C、 ’0’
D、’\0’
【第42句】:下列數據中屬于“字符串常量”的是( A )。
A、“a”
B、{ABC}
C、‘abc\0’
D、‘a’
若干個字符構成字符串
在C語言中,用單引號標識字符;用雙引號標識字符串
選項B,C,分別用{}和’’標識字符串
選項D,標識字符。
【第43句】:已知char x[]="hello", y[]={'h','e','a','b','e'};, 則關于兩個數組長度的正確描述是 B .
A、相同
B、x大于y
C、x小于y
D、以上答案都不對
C語言中,字符串后面需要一個結束標志位'\0',通常系統會自動添加。
對一維數組初始化時可采用字符串的形式(例如本題數組x),也可采用字符集合的形式(例如本題數組y)。在以字符串形式初始化時,數組x不盡要存儲字符串中的字符,還要存儲字符串后的結束標志位,因此數組x的長度為6;在以字符集合形式初始化時,數組y,僅存儲集合中的元素,因此數組y長度為5