C語言考前衝刺最重要的知識點複習

2021-03-31 14:20:34 字數 5243 閱讀 6161

總體上必須清楚的:

1)程式結構是三種: 順序結構 , 迴圈結構(三個迴圈結構), 選擇結構(if 和 switch)

2)讀程式都要從main()入口, 然後從最上面順序往下讀(碰到迴圈做迴圈,碰到選擇做選擇)。

3)計算機的資料在電腦中儲存是以二進位制的形式,資料存放的位置就是它的位址.

4)bit 是位,其值或者為0 或者為1。 byte 是指位元組, 乙個位元組=八個位.

5)一定要記住二進位制如何劃成十進位制。

概念常考到的:

1、編譯預處理不是c 語言的一部分,不佔執行時間,不要加分號。c 語言編譯的程式稱為源程式,它以ascii 數值存放在文字檔案中。

2、每個c 語言程式中main 函式是有且只有乙個。

3、在函式定義中不可以再定義函式。

4、演算法的是一定要有輸出的,但可以沒有輸入。

5、break 可用於迴圈結構和switch 語句。

6、逗號運算子的級別最低。

第一章1)合法的使用者識別符號考查:

合法的要求是由字母,數字,下劃線組成。有其它元素就錯了。並且第乙個必須為字母或是下劃線。第乙個為數字就錯了。

關鍵字不可以作為使用者識別符號號。main define scanf printf 都不是關鍵字。需要注意的地方:

if是可以做為使用者識別符號。因為if 中的第乙個字母大寫了,所以不是關鍵字。

2)實型資料的合法形式:

2.333e-1 就是合法的,且資料是2.333×10-1。

考試口訣:e 前e 後必有數,e 後必為整數。

3)字元資料的合法形式::

『1』是字元佔乙個位元組,"1"是字串佔兩個位元組(含乙個結束符號『\0』)

『0』的ascii 數值表示為48,'a' 的ascii 數值是97,'a'的ascii 數值是65。

一般考試表示單個字元錯誤的形式:'65' "1"

字元是可以進行算術運算的,記住: '0'-0=48

大寫字母和小寫字母轉換的方法: 'a'+32='a' 相互之間的差值是32(牢記)。

4) vc開發環境下,整型是4個位元組, 字元型是乙個位元組,單精度也是4個位元組:

考試時候一般會說,在16 位編譯系統,或者是32 位系統。碰到這種情況,不要去管,一樣做題。掌握整型是4個位元組, 字元型是乙個位元組,單精度也是4個位元組

5)轉義字元的考查:

在程式中 int a = 0x61,是把乙個十六進製制的數給變數a 注意這裡的0x 必須存在。在程式中 int a = 061, 是乙個八進位制的形式。

在轉義字元中,』\x6d』 才是合法的,0 不能寫,並且x 是小寫。

『\141』 是合法的, 0 是不能寫的。

『\108』是非法的,因為不可以出現8。

6)算術運算符號的優先級別:

同級別的有的是從左到右,有的是從右到左。

7)強制型別轉換:

一定是 (int)a 不是 int(a),注意型別上一定有括號的。

注意:(int)(a+b) 和(int)a+b 的區別。前是把a+b 轉型,後是把a 轉型再加b。

8)表示式的考查:

是表示式就一定有數值。

賦值表示式:表示式數值是最左邊的數值,a=b=5;該表示式為5,常量不可以賦值。

自加、自減表示式:假設a=5,++a(是為6), a++(為5);執行的機理:++a 是先把變數的數值加上1,然後把得到的數值放到變數a 中,然後再用這個++a 表示式的數值為6,而a++是先用該表示式的數值為5,然後再把a 的數值加上1 為6,再放到變數a 中。

進行了++a 和a++後在下面的程式中再用到a 的話都是變數a 中的6 了。

考試口訣:++在前先加後用,++在後先用後加。

逗號表示式:優先級別最低;表示式的數值逗號最右邊的那個表示式的數值。

(2,3,4)的表示式的數值就是4。

9)位運算的考查:

會有一到二題考試題目。

總的處理方法:幾乎所有的位運算的題目都要按這個流程來處理(先把十進位制變成二進位制再變成十進位制)。

例1: char a = 6, b;

b = a<<2; 這種題目的計算是先要把a 的十進位制6化成二進位制,再做位運算。

例2: 一定要記住,異或的位運算符號。0 異或 1 得到1。

0 異或 0 得到0。兩個女的生不出來。

1 異或 1 得到0。兩個男的生不出來。

考試記憶方法:一男(1)一女(0)才可以生個小孩(1)。

10)018 的數值是非法的,八進位制是沒有8 的,逢8就進1。

11)%符號兩邊要求是整數。不是整數就錯了。

12) 三種取整丟小數的情況:

int a =1.6;

int)a;

1/2; 3/2;

13)字元型和整數是近親:

char a = 65 ;

printf(「%c」, a); 得到的輸出結果:a

printf(「%d」, a); 得到的輸出結果:65

第二章1)printf 函式的格式考查:

%d 對應整型;%c 對應字元;%f 對應單精度等等。寬度的,左對齊等修飾。

%ld 對應 long int;%lf 對應double。

2)scanf 函式的格式考察:(近兩年考查重點,要重點複習)

注意該函式的第二個部分是&a 這樣表示的才是位址,不能寫成a;

scanf(「%d%d%*d%d」,&a,&b,&c); 跳過輸入的第三個資料。

典型習題:新視野教材第三冊第二章19,20,22,23要熟練掌握。

3)putchar ,getchar 函式的考查:

char a = getchar() 是沒有引數的,從鍵盤得到你輸入的乙個字元給變數a。

putchar(『y』)把字元y 輸出到螢幕中。

4)如何實現兩個變數x ,y 中數值的互換(要求背下來)

不可以把 x=y ,y=x; 要用中間變數 t=x;x=y;y=t。

5)如何實現保留三位小數,第四位四捨五入的程式,(要求背下來)

這個有推廣的意義,注意 x = (int)x 這樣的作用是把小數部分去掉。

第三章特別要注意:c 語言中是用[, , ]表示邏輯真的,[, ]表示邏輯假的。

1)關係表示式:

表示式的數值只能為1(表示為真),或0(表示假)

當關係的表達是為真的時候得到1。如 9>8 這個是真的,所以表示式的數值就是1;

2)邏輯表示式:

只能為1(表示為真),或0(表示假)

a) 共有&& || ! 三種邏輯運算符號。

b) !>&&>|| 三種邏輯運算子的優先順序。

c) 注意短路現象。考試比較喜歡考到。

d) 要如何表示 x 是比0大,比10小。03)if語句

else 是與最接近的if 且沒有else 的相組合的。

4)條件表示式:

表示式1 ?表示式2 :表示式3

注意是當非0 時候是表示式2 的數值,當為0 是就是表示式2 的數值。

考試口訣:真前假後。

5)switch 語句:

a) 一定要注意有break 和沒有break 的差別,書上(34 頁)的兩個例子,沒有break時候,只要有乙個case 匹配了,剩下的都要執行,有break 則是直接跳出了switch 語句。

b) switch 只可以和break 一起用,不可以和continue 用。

c) switch(x) x:是整型常量,字元型常量,列舉型資料。

第四章1)三種迴圈結構:

a)for() ; while(); do- while()三種。

b)for 迴圈當中必須是兩個分號,千萬不要忘記。

c)寫程式的時候一定要注意,迴圈一定要有結束的條件,否則成了死迴圈。

d) do-while()迴圈的最後乙個while();的分號一定不能夠丟。(當心上機改錯),do-while迴圈是至少執行一次迴圈。

2) break 和 continue 的差別

記憶方法:

break:是打破的意思,(破了整個迴圈)所以看見break 就退出真個一層迴圈。

continue:是繼續的意思,(繼續迴圈運算),但是要結束本次迴圈,就是迴圈體內剩下的語句不再執行,跳到迴圈開始,然後判斷迴圈條件,進行新一輪的迴圈。

3)巢狀迴圈

就是有迴圈裡面還有迴圈,這種比較複雜,要一層一層一步一步耐心的計算,一般記住兩層是處理二維陣列的。

4) while((c=getchar())!=』\n』) 和 while(c=getchar() !=』\n』)的差別

先看a = 3 != 2 和 (a=3)!=2 的區別:(!=號的級別高於=號所以第乙個先計算 3!=2) 第乙個a 的數值是得到的1;第二個a 的數值是3。

考試注意點: 括號在這裡的重要性。

第五章函式:是具有一定功能的乙個程式塊;是c語言的基本組成單位。

1) 函式的引數,返回數值(示意圖):

2)一定要注意引數之間的傳遞

實參和形參之間 ,和的差別。(考試的重點)

傳數值的話,形參的變化不會改變實參的變化。

傳位址的話,形參的變化就會有可能改變實參的變化。

3)函式宣告的考查:

一定要有:函式名,函式的返回型別,函式的引數型別。不一定要有:形參的名稱。

4)要求掌握的庫函式:

sqrt()fabs()pow()sin() 其中pow(a,b)是重點。23是由pow(2,3)表示的。

第六章指標變數的本質是用來放位址,而一般的變數是放數值的。

int *p ;中*p和p的差別:

*p可以當做變數來用;[, , , ],

p是當作位址來使用。

*p++ 和(*p)++的之間的差別:

*p++:位址會變化,*p)++:數值會要變化。

三名主義:(考試的重點)

陣列名:表示第乙個元素的位址。

函式名:表示該函式的入口位址。

字串常量名:表示第乙個字元的位址。

考試重要的話語:

指標變數是存放位址的。並且指向哪個就等價哪個,所有出現*p的地方都可以用它等價的代替。

例如:int a=2,*p=&a;

*p=*p+2;

(由於*p指向變數a,所以指向哪個就等價哪個,這裡*p等價於a,可以相當於是a=a+2)

指標變數兩種初始化

方法一:int a=2,*p=&a;(定義的同時初始化)

方法二:int a=2,*p;  (定義之後初始化)

p=&a;

第七章1)一維陣列的重要概念:

對a[10]這個陣列的討論:

1、a表示陣列名,是第乙個元素的位址,也就是元素a[0]的位址。

2、a是位址常量,所以只要出現a++,或者是a=a+2賦值的都是錯誤的。

C語言最重要的知識點

總體上必須清楚的 1 程式結構是三種 順序結構 選擇結構 分支結構 迴圈結構。2 讀程式都要從main 入口,然後從最上面順序往下讀 碰到迴圈做迴圈,碰到選擇做選擇 有且只有乙個main函式。3 計算機的資料在電腦中儲存是以二進位制的形式.資料存放的位置就是他的位址.4 bit是位是指為0或者1。b...

C語言最重要的知識點複習

總體上必須清楚的 1 程式結構是三種 順序結構 選擇結構 分支結構 迴圈結構。2 讀程式都要從main 入口,然後從最上面順序往下讀 碰到迴圈做迴圈,碰到選擇做選擇 有且只有乙個main函式。3 計算機的資料在電腦中儲存是以二進位制的形式.資料存放的位置就是他的位址.4 bit是位是指為0 或者1。...

C語言最重要的知識點複習

總體上必須清楚的 1 程式結構是三種 順序結構 迴圈結構 三個迴圈結構 選擇結構 if 和 switch 2 讀程式都要從main 入口,然後從最上面順序往下讀 碰到迴圈做迴圈,碰到選擇做選擇 3 計算機的資料在電腦中儲存是以二進位制的形式.資料存放的位置就是他的位址.4 bit是位是指為0或者1。...