總體上必須清楚的:
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。...