<pre id="bbfd9"><del id="bbfd9"><dfn id="bbfd9"></dfn></del></pre>

          <ruby id="bbfd9"></ruby><p id="bbfd9"><mark id="bbfd9"></mark></p>

          <p id="bbfd9"></p>

          <p id="bbfd9"><cite id="bbfd9"></cite></p>

            <th id="bbfd9"><form id="bbfd9"><dl id="bbfd9"></dl></form></th>

            <p id="bbfd9"><cite id="bbfd9"></cite></p><p id="bbfd9"></p>
            <p id="bbfd9"><cite id="bbfd9"><progress id="bbfd9"></progress></cite></p>
            C語言

            C語言練習題及其答案

            時間:2025-02-28 20:27:53 C語言 我要投稿
            • 相關推薦

            C語言練習題及其答案

              C語言是一門面向過程的、抽象化的通用程序設計語言,廣泛應用于底層開發。C語言能以簡易的方式編譯、處理低級存儲器。下面是小編幫大家整理的C語言練習題及其答案,僅供參考,大家一起來看看吧。

              C語言練習題及其答案1

              一、選擇題(7分,每小題0.5分)

              1.C語言源程序的基本單位是(B)。

              A過程 B函數 C子程序 D標識符

              2.下列程序的輸出結果是(C)。

              main( )

              { int a=7,b=5;

              printf("%d ",b=b/a);

              }

              A 5 B 1 C 0 D不確定值

              3.假設變量a,b均為整型,表達式(a=5,b=2,a>b?a++:b++,a+b)的值是(B)。

              A 7 B 8 C9 D 2

              4.設a為int型變量,執行下列賦值語句后,a的取值分別是()。

              a=125.534; a=(int)125.521%4; a=5<<2;

              A 125,31,1 B 125,1,20 C 125,31,20 D 125.534,2,20

              5.設有如下程序段,下面描述中正確的是(C)。

              int k=10;while(k=0) k=k-1;

              A循環執行一次 B循環是無限循環 C循環體語句一次也不執行 D循環體語句執行一次

              6.下面選項中正確的賦值語句是(設char a[5],*p=a;)()。

              A p="abcd"; B a="abcd"; C *p="abcd"; D *a="abcd";

              13.設有以下程序段,則值為6的表達式是()。

              struct st { int n; struct st *next;};

              static struct st a[3]={5,&a[1],7,&a[2],9,0},*p;

              p=&a[0];

              A p++->n B ++p->nC p->n++ D (*p).n++

              14.C語言中的文件類型只有()。

              A索引文件和文本文件兩種 B文本文件一種

              C二進制文件一種D ASCII碼文件和二進制文件兩種

              7.在C語言程序中,以下說法正確的是(A )。

              A函數的定義可以嵌套,但函數的調用不可以嵌套

              B函數的定義不可以嵌套,但函數的調用可以嵌套

              C函數的定義和函數的調用都不可以嵌套

              D函數的定義和函數的調用都可以嵌套

              8.以下函數調用語句中含有(A)個實參。

              func((e1,e2),(e3,e4,e5));

              A 2B 3 C 5 D語法錯誤

              9.以下程序的輸出結果為()。

              #define ADD(x) x*x

              main( )

              { int a=4,b=6,c=7,d=ADD(a+b)*c;

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

              }

              A d=70 B d=80 C d=140 D d=700

              10.已知職工記錄描述如下,在Turbo C中,系統為變量w分配()字節的空間。

              struct worker

              { int no;

              char name[20];

              char sex;

              union

              { int day; int month;int year;}birth;

              } w;

              A 29 B 20 C 25 D 6

              11.設有以下定義,值為5的枚舉常量是()。

              enum week{sun,mon=4,tue,wed,thu,fri,sat}w;

              A tue B satC fri D thu

              二判斷對錯,對的.劃“√”,錯的劃“×”(5分,每小題0.5分)

              1.在Turbo C中,整型數據在內存中占2個字節。()

              2.int i=20;switch(i/10){case 2:printf("A");case1:printf("B");}的輸出結果為A。()

              3.break語句用在循環體中,可結束本層循環,continue語句用在循環體中,可結束本次循環。()

              4.函數的遞歸調用不過是一個函數直接或間接地調用它自身。()

              5.函數strlen("ASDFG ")的值是7。()

              6.通過return語句,函數可以帶回一個或一個以上的返回值。()

              7.結構體類型只有一種。()

              8.char *p="girl";的含義是定義字符型指針變量p,p的值是字符串"girl"。()

              9.若有定義:char *p(char a[10]);則p是函數名。()

              10.用fopen("file","r+");打開的文件"file"可以進行修改。()

              三寫出下列程序的運行結果(10分,每小題2分)

              1.float average (floatarray[10])

              {int i;

              float aver,sum=array[0];

              for (i=1;i<10;i++)

              sum=sum+array[i];

              aver=sum/10;

              return(aver);

              }

              main( )

              {float score[10]={89,67.5,78,91,56,82.5,65,70,79,88},aver;

              int i;

              aver=average (score);

              printf (“averagescore is %5.2f ”,aver);

              }

              2.main( )

              { char a[5]={‘A’,‘B’,‘C’,‘D’,‘E’},*p=a,**pa;

              for(p=0;p<a+5;p++)

              printf(“%2c”,*p);

              printf(“ ”);

              printf(“%2c ”,**(pa=&p));

              }

              3.main( )

              { int a,b,s=0;

              for(a=1,b=1;a<=100;a++)

              { if(b>=20)break;

              if(b%3==1)

              {b+=3; continue; }

              b-=5;

              }

              printf(“a=%d b=%d ”,a,b);

              }

              4.main()

              { printf(“main() :%d ”,fact(5));

              fact(-5);

              }

              fact(int value)

              { int f;

              if(value<0)

              { printf(“Argerror ");

              return(-1);

              }

              else if(value==1||value==0) f=1;

              elsef=value*fact(value-1)+1;

              printf(“This calledvalue=%d ”,f);

              return f;

              }

              5.main( )

              { int a=012,b=0x12,k=12;

              char c=‘102’,d=‘ ’;

              printf(“a=%d b=%d k=%d ”,a,b,k);

              printf(“c=%c,d=%c%o ”,c,d,a);

              a=‘A’; c=49;

              printf(“a=%d c=%c ”,a,c);

              }

              四 閱讀下列程序,在處填入適當內容,使程序完整(8分,每個空1分)

              1.有一個3*4矩陣,求其中的最大元素。

              max_value((1))

              { int i,j,max;

              max=array[0][0];

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

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

              if(array[i][j]>max)

              max=array[i][j];

              (2);

              }

              main( )

              {int a[3][4], i,j;

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

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

              (3);

              printf(“maxvalue is %d ”,max_value(a));

              }

              2.輸入x、y兩個整數,按先大后小的順序輸出x、y。

              #include“stdio.h”

              main( )

              { int x,y, *px,*py, (4);

              scanf(“%d%d”,&x,&y);

              (5);(6);

              if(x<y)

              {p=px; px=py; py=p;}

              printf(“x=%d,y=%d ”,x,y);

              printf(“MAX=%d,MIN=%d ”,*px,*py);

              }

              3.用選擇排序法對任意10個整數按照由小到大排序。

              main()

              { int a[11],i,j,k,t;

              printf("Please input 10numbers: ");

              for(i=1;i<11;i++) scanf("%d",&a[i]);

              printf(" ");

              for(i=1;i<=9;i++)

              {(7);

              for(j=i+1; (8);j++)

              if(a[j]>a[k]) k=j;

              if(k!=i)

              { t=a[k]; a[k]=a[i];a[i]=t;}

              }

              printf("The sortednumbers: ");

              for(i=1;i<11;i++) printf("%d ",a[i]);

              }

              答案

              一選擇題(7分,每小題0.5分)

              1. B2. C 3. B 4. B 5. C

              6. A7. B 8. A 9. A 10. C

              11. A12. A 13. B 14. D

              二判斷對錯,對的劃“√”,錯的劃“×”(5分,每小題0.5分)

              1.× 2.× 3.√ 4.√ 5.×

              6.× 7.× 8.× 9.√ 10.√

              三寫出下列程序的運行結果(10分,每小題2分)

              1. 2. 3.

              4. 5.

              四閱讀下列程序,在處填入適當內容,使程序完整(8分,每個空1分)

              1.(1)intarray[3][4](int array[][4])(2)return(max) (3)scanf(“%d”,&a[i][j])

              2.(4)*p (5)px=&x(py=&y) (6)py=&y(px=&x)

              3.(7) (8)

              C語言練習題及其答案2

              1). 關于C語言的變量,以下敘述中錯誤的是( )

              A.所謂變量是指在程序運行過程中其值可以被改變的量

              B.變量所占的存儲單元地址可以隨時改變

              C.程序中用到的所有變量都必須先定義后才能使用

              D.由三條下劃線構成的符號名是合法的變量名

              正確答案:B

              答案解析:變量是指在程序運行過程中其值可以改變的值,一個變量實質上是代表了內存中的某個存儲單元。在程序中對某個變量的操作實際上就是對這個存儲單元的操作,程序運行期間,這個分配的存儲單元不會改變,但是其值可以變化。變量命名要符合標識符的規定,其中下劃線是標識符的組成字符。程序中所有變量都必須先定義后使用。

              2). 當變量c的值不為2、4、6時,值也為″真″的表達式是( )

              A.(c==2)||(c==4)||(c==6)

              B.(c>=2 && c<=6)&&!(c%2)

              C.(c>=2 &&c<=6)&&(c%2!=1)

              D.(c>=2 && c<=6) || (c!=3)|| (c!=5)

              正確答案:D

              答案解析:邏輯或運算中,只要有一項為真,表達式的值就為真,故選項D中c的值不為2、4、6時,那么表達式(c>=2&& c<=6)以及(c!=3)、(c!=5)必有一個成立,表達式的值也為真。

              3). 在C語言中,函數返回值的類型最終取決于

              A.函數定義時在函數首部所說明的函數類型

              B.return語句中表達式值的類型

              C.調用函數時主調函數所傳遞的實參類型

              D.函數定義時形參的類型

              正確答案:A

              答案解析:在C語言中,應當在定義函數時指定函數值的類型,凡不加類型說明的函數,一律按整型處理。在定義函數時,對函數值說明的類型一般應該和return語句中的表達式類型一致。如果函數值的類型和return語句中的表達式類型不一致,則以函數類型為主,即函數類型決定返回值的類型。

              4). 以下敘述中正確的是( )

              A.在C語言中,預處理命令行都以″#″開頭

              B.預處理命令行必須位于C源程序的起始位置

              C.#include 必須放在C程序的開頭

              D.C語言的預處理不能實現宏定義和條件編譯的功能

              正確答案:A

              答案解析:在C語言中,凡是以″#″號開頭的行,都稱為″編譯預處理″命令行。預處理命令可以放在程序中的任何位置,其有效范圍是從定義開始到文件結束。預處理命令有宏定義、文件包含和條件編譯三類。#include 命令行表示程序中要引用C標準函數庫中的標準輸入輸出函數。

              5). 下列敘述中,不屬于測試的特征的是

              A.測試的挑剔性

              B.完全測試的不可能性

              C.測試的可靠性

              D.測試的經濟性

              正確答案:C

              答案解析:軟件測試的目標是在精心控制的環境下執行程序,以發現程序中的`錯誤,給出程序可靠性的鑒定。它有3個方面的重要特征,即測試的挑剔性、完全測試的不可能性及測試的經濟性。其中,沒有測試的可靠性這一說法。

              6). 以下選項中不屬于C語言標識符的是( )

              A.用戶標識符

              B.關鍵字

              C.常量

              D.預定義標識符

              正確答案:C

              答案解析:C語言的標識符可分為以下3類:①關鍵字。C語言預先規定了一批標識符,它們在程序中都代表著固定的含義,不能另作他用。這些字符稱為關鍵字。例如,int、double、if、else、while、for等。②預定義標識符。即預先定義并具有特定含義的標識符。③用戶標識符。由用戶根據需要定義的標識符稱為用戶標識符,又稱自定義標識符,一般用來給變量、函數、數組等命名。

              7). 以下關于字符串的敘述中正確的是( )

              A.兩個字符串中的字符個數相同時才能進行字符串大小的比較

              B.可以用關系運算符對字符串的大小進行比較

              C.空串比空格打頭的字符串小

              D.C語言中有字符串類型的常量和變量

              正確答案:C

              答案解析:C語言本身并沒有設置一種類型來定義字符串變量,卻允許使用″字符串常量″。字符串常量是由雙引號括起來的一串字符。任意兩個字符串的大小比較要調用字符串比較函數strcmp(s1,s2 )來進行,其比較的方法是依次對s1和s2中對應位置上的字符兩兩進行比較,當出現第一對不相同的字符時,即由這兩個字符決定所在串的大小(比較字符大小的依據是其ASCⅡ碼值)。

              8). 下列敘述中正確的是( )。

              A.調用printf( )函數時,必須要有輸出項

              B.使用put )函數時,必須在之前包含頭文件stdio.h

              C.在C語言中,整數可以以二進制、八進制或十六進制的形式輸出

              D.調節get )函數讀入字符時,可以從鍵盤上輸入字符所對應的ASCII碼

              正確答案:B

              答案解析:選項A,若printf函數沒有輸出項,且格式字符串中不含格式信息,則輸出的是格式字符串本身,若格式字符串含有格式信息,運行時則出現錯誤提示;選項C,在C語言中,整數可以十進制、八進制或十六進制的形式輸出;選項D,getchar函數是從標準輸入設備讀取一個字符。

              9). 以下結構體類型說明和變量定義中正確的是( )

              A.typedefstruct { int n; char c; } REC; REC t1,t2;

              B.structREC ; { int n; char c; }; REC t1,t2;

              C.typedefstruct REC; { int n=0; char c=′A′; } t1,t2;

              D.struct{ int n; char c; } REC; REC t1,t2;

              正確答案:A

              答案解析:定義結構體類型的一般形式為:struct 結構體名 {成員列表};struct 結構體名后不能加″;″號,所以選項B、C)錯誤,選項D中定義無名稱的結構體類型同時定義結構體變量形式應為struct t1,t2;選項A為用戶自定義類型,其為正確的定義形式。

              10). 若實體A和B是一對多的聯系,實體B和C是一對一的聯系,則實體A和C的聯系是( )

              A.一對一

              B.一對多

              C.多對一

              D.多對多

              正確答案:B

              答案解析:由于B和C有一一對應的聯系,而A和B只間有一對多的聯系,則通過關系之間的傳遞,則A和C之間也是一對多的聯系。

              11). 待排序的關鍵碼序列為(15,20,9,30,67.65,45,90),要按關鍵碼值遞增的順序排序,采取簡單選擇排序法,第一趟排序后關鍵碼15被放到第( )個位置。

              A.2

              B.3

              C.4

              D.5

              正確答案:B

              答案解析:選擇排序的基本思想是掃描整個線性表,從中選出最小的元素,將它交換到表的最前面,然后對剩下的子表采用同樣的方法,直到子表為空。所以第一趟排序后,將選出最小的元素9放在第一個位置,元素15則被交換放在第三個位置。

            【C語言練習題及其答案】相關文章:

            C語言練習題及答案10-23

            C語言考前練習題及答案11-10

            C語言程序基礎練習題帶答案09-26

            最新C語言知識輔導練習題及答案10-23

            C語言練習題06-13

            C語言程序設計練習題附答案06-03

            C語言試題及答案07-26

            C語言經典例題及答案06-19

            C語言習題及答案09-24

                    <pre id="bbfd9"><del id="bbfd9"><dfn id="bbfd9"></dfn></del></pre>

                    <ruby id="bbfd9"></ruby><p id="bbfd9"><mark id="bbfd9"></mark></p>

                    <p id="bbfd9"></p>

                    <p id="bbfd9"><cite id="bbfd9"></cite></p>

                      <th id="bbfd9"><form id="bbfd9"><dl id="bbfd9"></dl></form></th>

                      <p id="bbfd9"><cite id="bbfd9"></cite></p><p id="bbfd9"></p>
                      <p id="bbfd9"><cite id="bbfd9"><progress id="bbfd9"></progress></cite></p>
                      飘沙影院