



版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、C 語(yǔ)言最重要的知識(shí)點(diǎn)復(fù)習(xí)資料總體上必須清楚的 :1)程序結(jié)構(gòu)是三種:順序結(jié)構(gòu)、選擇結(jié)構(gòu) (分支結(jié)構(gòu) ) 、循環(huán)結(jié)構(gòu)。2) 讀程序都要從main() 入口 , 然后從最上面順序往下讀( 碰到循環(huán)做循環(huán), 碰到選擇做選擇) ,有且只有一個(gè)main 函數(shù)。3)計(jì)算機(jī)的數(shù)據(jù)在電腦中保存是以二進(jìn)制的形式 . 數(shù)據(jù)存放的位置就是他的地址 .4)bit 是位是指為 0 或者 1。 byte 是指字節(jié) , 一個(gè)字節(jié)= 八個(gè)位 .概念常考到的:1、編譯預(yù)處理不是C 語(yǔ)言的一部分,不占運(yùn)行時(shí)間,不要加分號(hào)。C 語(yǔ)言編譯的程序稱為源程序,它以ASCII 數(shù)值存放在文本文件中。2、 define PI 3.1415
2、926;這個(gè)寫法是錯(cuò)誤的,一定不能出現(xiàn)分號(hào)。3、每個(gè) C 語(yǔ)言程序中main 函數(shù)是有且只有一個(gè)。4、在函數(shù)中不可以再定義函數(shù)。5、算法:可以沒有輸入,但是一定要有輸出。6、 break 可用于循環(huán)結(jié)構(gòu)和switch 語(yǔ)句。7、逗號(hào)運(yùn)算符的級(jí)別最低,賦值的級(jí)別倒數(shù)第二。第一章C 語(yǔ)言的基礎(chǔ)知識(shí)第一節(jié)、對(duì) C 語(yǔ)言的基礎(chǔ)認(rèn)識(shí)1、 C 語(yǔ)言編寫的程序稱為源程序 ,又稱為 編譯單位 。2、 C 語(yǔ)言書寫格式是自由的,每行可以寫多個(gè)語(yǔ)句,可以寫多行。3、一個(gè) C 語(yǔ)言程序有且只有一個(gè)main 函數(shù),是程序運(yùn)行的起點(diǎn)。第二節(jié)、熟悉 vc+1、 VC 是軟件,用來運(yùn)行寫的C 語(yǔ)言程序。2、每個(gè)C 語(yǔ)言程序
3、寫完后,都是先編譯,后鏈接,最后運(yùn)行。(.c-.obj-.exe)這個(gè)過程中注意 .c 和 .obj 文件時(shí)無(wú)法運(yùn)行的,只有.exe 文件才可以運(yùn)行。 (??迹。┑谌?jié)、標(biāo)識(shí)符1、標(biāo)識(shí)符(必考內(nèi)容) :合法的要求是由字母,數(shù)字,下劃線組成。有其它元素就錯(cuò)了。并且第一個(gè)必須為字母或則是下劃線。第一個(gè)為數(shù)字就錯(cuò)了2、標(biāo)識(shí)符分為關(guān)鍵字、預(yù)定義標(biāo)識(shí)符、用戶標(biāo)識(shí)符。關(guān)鍵字:不可以作為用戶標(biāo)識(shí)符號(hào)。 main define scanf printf 都不是關(guān)鍵字。迷惑你的地方 If 是可以做為用戶標(biāo)識(shí)符。因?yàn)?If 中的第一個(gè)字母大寫了,所以不是關(guān)鍵字。預(yù)定義標(biāo)識(shí)符:背誦definescanfprintf
4、include。記住預(yù)定義標(biāo)識(shí)符可以做為用戶標(biāo)識(shí)符。用戶標(biāo)識(shí)符:基本上每年都考,詳細(xì)請(qǐng)見書上習(xí)題。第四節(jié):進(jìn)制的轉(zhuǎn)換十進(jìn)制轉(zhuǎn)換成二進(jìn)制、八進(jìn)制、十六進(jìn)制。二進(jìn)制、八進(jìn)制、十六進(jìn)制轉(zhuǎn)換成十進(jìn)制。第五節(jié):整數(shù)與實(shí)數(shù)1)C 語(yǔ)言只有八、十、十六進(jìn)制,沒有二進(jìn)制。但是運(yùn)行時(shí)候,所有的進(jìn)制都要轉(zhuǎn)換成二精選文檔進(jìn)制來進(jìn)行處理。 (考過兩次)a、 C 語(yǔ)言中的八進(jìn)制規(guī)定要以0 開頭。 018 的數(shù)值是非法的,八進(jìn)制是沒有8 的,逢8進(jìn) 1。b、 C 語(yǔ)言中的十六進(jìn)制規(guī)定要以0x 開頭。2)小數(shù)的合法寫法: C 語(yǔ)言小數(shù)點(diǎn)兩邊有一個(gè)是零的話,可以不用寫。1.0 在 C 語(yǔ)言中可寫成 1.0.1 在 C 語(yǔ)言中
5、可以寫成 .1。3)實(shí)型數(shù)據(jù)的合法形式:a、 2.333e-1 就是合法的,且數(shù)據(jù)是 2.333× 10-1。b、考試口訣 : e 前 e 后必有數(shù), e 后必為整數(shù) 。請(qǐng)結(jié)合書上的例子。4) 整型一般是4 個(gè)字節(jié) , 字符型是1 個(gè)字節(jié),雙精度一般是8 個(gè)字節(jié):long int x;表示 x 是長(zhǎng)整型。unsigned int x; 表示 x 是無(wú)符號(hào)整型。第六、七節(jié):算術(shù)表達(dá)式和賦值表達(dá)式核心:表達(dá)式一定有數(shù)值!1、算術(shù)表達(dá)式: +,-, * , /, %考試一定要注意: “ /” 兩邊都是整型的話,結(jié)果就是一個(gè)整型。3/2 的結(jié)果就是 1.“ /” 如果有一邊是小數(shù),那么結(jié)果就
6、是小數(shù)。3/2.0 的結(jié)果就是 0.5“ %”符號(hào)請(qǐng)一定要注意是余數(shù),考試最容易算成了除號(hào)。) %符號(hào)兩邊要求是整數(shù)。不是整數(shù)就錯(cuò)了。2、賦值表達(dá)式:表達(dá)式數(shù)值是最左邊的數(shù)值,a=b=5;該表達(dá)式為5,常量不可以賦值。1、 int x=y=10:錯(cuò)啦,定義時(shí),不可以連續(xù)賦值。2、 int x,y;x=y=10;對(duì)滴,定義完成后,可以連續(xù)賦值。3、賦值的左邊只能是一個(gè)變量。4、 int x=7.7 ;對(duì)滴, x 就是 75、 float y=7 ;對(duì)滴, x 就是 7.03、復(fù)合的賦值表達(dá)式:int a=2 ;a*=2+3 ;運(yùn)行完成后,a 的值是 10。( a=a*(2+3)=2*5=10 )
7、一定要注意,首先要在2+3 的上面打上括號(hào)。變成(2+3)再運(yùn)算。4、自加表達(dá)式:自加、自減表達(dá)式:假設(shè)a=5, +a(是為 6), a+(為 5);運(yùn)行的機(jī)理: +a 是先把變量的數(shù)值加上1,然后把得到的數(shù)值放到變量a 中,然后再用這個(gè) +a 表達(dá)式的數(shù)值為6,而 a+是先用該表達(dá)式的數(shù)值為5,然后再把a(bǔ) 的數(shù)值加上1 為 6,再放到變量a 中。 進(jìn)行了 +a 和 a+后 在下面的程序中再用到a 的話都是變量a 中的 6 了。考試口訣 : + 在前先加后用,+在后先用后加。5、逗號(hào)表達(dá)式:優(yōu)先級(jí)別最低。表達(dá)式的數(shù)值逗號(hào)最右邊的那個(gè)表達(dá)式的數(shù)值。( 2, 3, 4)的表達(dá)式的數(shù)值就是4。z=(
8、 2,3, 4) (整個(gè)是賦值表達(dá)式) 這個(gè)時(shí)候 z 的值為 4。(有點(diǎn)難度哦! )z=2,3, 4 (整個(gè)是逗號(hào)表達(dá)式)這個(gè)時(shí)候z 的值為 2。補(bǔ)充:1、空語(yǔ)句不可以隨意執(zhí)行,會(huì)導(dǎo)致邏輯錯(cuò)誤。2精選文檔2、注釋是最近幾年考試的重點(diǎn),注釋不是C 語(yǔ)言,不占運(yùn)行時(shí)間,沒有分號(hào)。不可以嵌套!3、強(qiáng)制類型轉(zhuǎn)換:一定是( int) a 不是int ( a),注意類型上一定有括號(hào)的。注意( int )( a+b) 和( int ) a+b 的區(qū)別。前是把 a+b 轉(zhuǎn)型,后是把a(bǔ) 轉(zhuǎn)型再加b。4、三種取整丟小數(shù)的情況:、 int a =1.6 ;、 (int)a ;、 1/2; 3/2;第八節(jié)、字符1)字
9、符數(shù)據(jù)的合法形式::'1' 是字符占一個(gè)字節(jié),"1" 是字符串占兩個(gè)字節(jié)(含有一個(gè)結(jié)束符號(hào))。'0' 的 ASCII 數(shù)值表示為48, 'a' 的 ASCII 數(shù)值是 97, 'A' 的 ASCII 數(shù)值是 65。一般考試表示單個(gè)字符錯(cuò)誤的形式:'65'"1"字符是可以進(jìn)行算術(shù)運(yùn)算的,記住:'0'-0=48大寫字母和小寫字母轉(zhuǎn)換的方法:'A'+32='a'相互之間一般是相差32。2)轉(zhuǎn)義字符:轉(zhuǎn)義字符分為一般轉(zhuǎn)義字符、八進(jìn)制轉(zhuǎn)義
10、字符、十六進(jìn)制轉(zhuǎn)義字符。一般轉(zhuǎn)義字符:背誦0、 n、”、。八進(jìn)制轉(zhuǎn)義字符:141是合法的,前導(dǎo)的 0 是不能寫的。十六進(jìn)制轉(zhuǎn)義字符:x6d 才是合法的,前導(dǎo)的0 不能寫,并且x 是小寫。3、字符型和整數(shù)是近親:兩個(gè)具有很大的相似之處char a = 65 ;printf( “%c”, a);得到的輸出結(jié)果:aprintf( “%d”, a);得到的輸出結(jié)果:65第九章、位運(yùn)算1)位運(yùn)算的考查:會(huì)有一到二題考試題目。總的處理方法:幾乎所有的位運(yùn)算的題目都要按這個(gè)流程來處理(先把十進(jìn)制變成二進(jìn)制再變成十進(jìn)制) 。例 1:char a = 6, b;b = a<<2;這種題目的計(jì)算是先要
11、把a(bǔ) 的十進(jìn)制6 化成二進(jìn)制,再做位運(yùn)算。例 2:一定要記住,異或的位運(yùn)算符號(hào)” ”。 0 異或1 得到 1。0 異或0 得到 0。兩個(gè)女的生不出來??荚囉洃浄椒ǎ阂荒?(1)一女 (0)才可以生個(gè)小孩(1) 。例 3:在沒有舍去數(shù)據(jù)的時(shí)候,<<左移一位表示乘以2; >>右移一位表示除以2。第二章第一節(jié):數(shù)據(jù)輸出(一)(二)1、使用 printf 和 scanf 函數(shù)時(shí),要在最前面加上#include “stdio.h ”2、 printf 可以只有一個(gè)參數(shù),也可以有兩個(gè)參數(shù)。(選擇題考過一次)3、 printf (“ 第一部分”,第二部分);把第二部分的變量、表達(dá)式、
12、常量以第一部分的形式展現(xiàn)出來!4、 printf (“ a=%d, b= %d”,12, 34) 考試重點(diǎn)!一定要記住是將12 和 34 以第一部分的形式現(xiàn)在在終端也就是黑色的屏幕上??荚嚭诵臑椋阂荒R粯?。在黑色屏幕上面顯示為a=12,b=34printf (“ a=%d, n b=%d”, 12, 34)那么輸出的結(jié)果就是:a=12,3精選文檔b=345、 int x=017 ; 一定要弄清楚為什么是這個(gè)結(jié)果!過程很重要 printf (“ %d”, x); 15printf (“ %o”, x); 17printf (“ %#o”, x); 017printf (“ %x ”, x);
13、11printf (“ %#x ”, x); 0x116、 int x=12 , y=34;注意這種題型char z= a;printf (“ %d ”, x, y); 一個(gè)格式說明,兩個(gè)輸出變量,后面的y 不輸出printf (“ %c”, z);結(jié)果為: 12a7、一定要背誦的格式說明表示內(nèi)容格式說明表示內(nèi)容%d整型int%c字符char%ld長(zhǎng)整型long int%s字符串%f浮點(diǎn)型float%o八進(jìn)制%lfdouble%#o帶前導(dǎo)的八進(jìn)制%輸出一個(gè)百分號(hào)%x十六進(jìn)制%5d%#x帶前導(dǎo)的十六進(jìn)制舉例說明:printf (“ %2d”, 123 );第二部分有三位,大于指定的兩位,原樣輸出
14、123printf (“ %5d”, 123 );第二部分有三位,小于指定的五位,左邊補(bǔ)兩個(gè)空格123printf (“ %10f ”,1.25 ); 小數(shù)要求補(bǔ)足 6 位的,沒有六位的補(bǔ) 0,。結(jié)果為 1.250000 printf (“ %5.3f ”,125 ); 小數(shù)三位,整個(gè)五位,結(jié)果為 1.250(小數(shù)點(diǎn)算一位)printf (“ %3.1f ”,1.25 );小數(shù)一位,整個(gè)三位,結(jié)果為1.3(要進(jìn)行四舍五入)第三節(jié)數(shù)據(jù)輸入1、 scanf(“ a=%d, b= %d”, &a , &b ) 考試超級(jí)重點(diǎn)!一定要記住是以第一部分的格式在終端輸入數(shù)據(jù)??荚嚭诵臑椋阂荒?/p>
15、一樣 。在黑色屏幕上面輸入的為a=12,b=34 才可以把12 和 34 正確給 a 和 b 。有一點(diǎn)不同也不行。2、 scanf(“ %d,%d”, x, y);這種寫法絕對(duì)錯(cuò)誤,scanf 的第二個(gè)部分一定要是地址!scanf(“ %d,%d”, &x , &y );注意寫成這樣才可以!3、特別注意指針在scanf 的考察例如:int x=2 ; int *p=&x ;scanf(“ %d”, x);錯(cuò)誤scanf(“ %d”, p);正確scanf(“ %d”, &p );錯(cuò)誤scanf(“%d ”, *p )錯(cuò)誤4、指定輸入的長(zhǎng)度(考試重點(diǎn))終端輸入:
16、1234567scanf(“ %2d%4d%d ”, &x , &y , &z ); x 為 12, y 為 3456, z 為 7終端輸入: 1 234567由于 1 和 2 中間有空格,所以只有1 位給 xscanf(“ %2d%4d%d ”, &x , &y , &z ); x 為 1, y 為 2345, z 為 675、字符和整型是近親:int x=97 ;printf (“ %d”,x);結(jié)果為 974精選文檔printf (“ %c”,x);結(jié)果為a6、輸入時(shí)候字符和整數(shù)的區(qū)別(考試超級(jí)重點(diǎn))scanf(“ %d”, &x
17、);這個(gè)時(shí)候輸入1,特別注意表示的是整數(shù)1scanf(“ %c”, &x );這個(gè)時(shí)候輸入1,特別注意表示的是字符1ASCII 為整數(shù) 48。補(bǔ)充說明:1) scanf 函數(shù)的格式考察:注意該函數(shù)的第二個(gè)部分是&a 這樣的地址,不是a;scanf(“%d%d%*d%d ”,&a,&b,&c);跳過輸入的第三個(gè)數(shù)據(jù)。2) putchar ,getchar 函數(shù)的考查:chara = getchar() 是沒有參數(shù)的,從鍵盤得到你輸入的一個(gè)字符給變量a。putchar(y)把字符 y 輸出到屏幕中。3)如何實(shí)現(xiàn)兩個(gè)變量x , y 中數(shù)值的互換(要求背下來)不
18、可以把x=y ,y=x;要用中間變量t=x ;x=y ; y=t 。4)如何實(shí)現(xiàn)保留三位小數(shù),第四位四舍五入的程序,(要求背下來)y= ( int)( x*100+0.5 ) /100.0這個(gè)保留兩位,對(duì)第三位四舍五入y= ( int)( x*1000+0.5 ) /1000.0 這個(gè)保留三位,對(duì)第四位四舍五入y= ( int)( x*10000+0.5 ) /10000.0 這個(gè)保留四位,對(duì)第五位四舍五入這個(gè)有推廣的意義,注意x = (int ) x 這樣是把小數(shù)部分去掉。第三章特別要注意:C 語(yǔ)言中是用非0 表示邏輯真的,用0 表示邏輯假的。C 語(yǔ)言有構(gòu)造類型,沒有邏輯類型。關(guān)系運(yùn)算符號(hào):
19、注意<= 的寫法, =和 =的區(qū)別?。荚囍攸c(diǎn))if 只管后面一個(gè)語(yǔ)句,要管多個(gè),請(qǐng)用大括號(hào)!1)關(guān)系表達(dá)式:a、表達(dá)式的數(shù)值只能為1(表示為真),或 0(表示假) 。如 9>8 這個(gè)關(guān)系表達(dá)式是真的,所以9>8 這個(gè)表達(dá)式的數(shù)值就是1。如 7<6 這個(gè)關(guān)系表達(dá)式是假的,所以7<6 這個(gè)表達(dá)式的數(shù)值就是0b、考試最容易錯(cuò)的:就是int x=1,y=0,z=2;x<y<z 是真還是假?帶入為1<0<2,從數(shù)學(xué)的角度出發(fā)肯定是錯(cuò)的,但是如果是C 語(yǔ)言那么就是正確的!因?yàn)橐?<0 為假得到0,表達(dá)式就變成了 0<2 那么運(yùn)算結(jié)果就是1
20、,稱為了真的了!c、等號(hào)和賦值的區(qū)別!一定記住“=”就是賦值, “ = =”才是等號(hào)。雖然很多人可以背誦,但我依然要大家一定好好記住,否則,做錯(cuò)了,我一定會(huì)強(qiáng)烈的鄙視你!2)邏輯表達(dá)式:核心:表達(dá)式的數(shù)值只能為1(表示為真),或 0(表示假)。a)共有 &&|! 三種邏輯運(yùn)算符號(hào)。b) ! >&&>| 優(yōu)先的級(jí)別。c)注意短路現(xiàn)象??荚嚤容^喜歡考到。詳細(xì)請(qǐng)見書上例子,一定要會(huì)做例1 和例 2d) 表示 x 小于 0 大于 10 的方法。0<x<10 是不行的(一定記?。?。 是先計(jì)算0<x 得到的結(jié)果為1 或則 0;再用 0,或 1
21、 與10 比較得到的總是真(為1)。所以一定 要用(0<x)&&(x<10)表示比 0 大比 10 小。3) if語(yǔ)句a、 else 是與最接近的if 且沒有 else 的語(yǔ)句匹配。b、交換的程序?qū)懛ǎ簍=x ; x=y ; y=t ;5精選文檔c、 if ( a<b) t=a;a=b;b=t;if ( a<b) t=a;a=b;b=t; 兩個(gè)的區(qū)別,考試多次考到了!d、單獨(dú)的if 語(yǔ)句: if ( a<b) t=a;標(biāo)準(zhǔn)的 if 語(yǔ)句: if ( a<b) min=a ;elsemin=b ;嵌套的 if 語(yǔ)句: if ( a<b)i
22、f ( b>c) printf( “ok! ”);多選一的if 語(yǔ)句 if (a= =t ) printf( “a”);else if ( b= =t ) printf( “b”);else if ( c= =t ) printf( “c”);else pritnf( “d”);通過習(xí)題,要熟悉以上幾種if 語(yǔ)句!經(jīng)典考題:結(jié)合上面四種if 語(yǔ)句題型做題,答錯(cuò)了,請(qǐng)自行了斷!預(yù)備,開始!inta=1, b=0 ;if (! a) b+ ;(即如果a 的值是 0,則 !a=1 ,則執(zhí)行b+,也就是說當(dāng)a 的值等于0 的時(shí)候才會(huì)執(zhí)行b+。)else if( a= =0)if ( a)b+=2
23、 ;else b+=3;請(qǐng)問 b 的值是多少?如果沒有看懂題目,你千萬(wàn)不要自行了斷,這樣看得懂不會(huì)做的人才會(huì)有理由的活著。正確的是 b 為 3。int a=1, b=0 ;if (! a) b+ ;是假的不執(zhí)行else if( a= =0 )是假的部執(zhí)行if( );屬于 else if 的嵌套 if 語(yǔ)句,不執(zhí)行。a b+=2else b+=3 ;if-else-if 語(yǔ)句沒有一個(gè)正確的,就執(zhí)行else 的語(yǔ)句!4)條件表達(dá)式:表達(dá)式 1?表達(dá)式2 :表達(dá)式 3a、考試口訣 :真前假后。b、注意是當(dāng)表達(dá)式1 的數(shù)值是 非 0 時(shí),才采用表達(dá)式 2 的數(shù)值做為整個(gè)運(yùn)算結(jié)果,當(dāng)表達(dá)式 1 的數(shù)值
24、為 0 時(shí), 就用表達(dá)式 3 的數(shù)值做為整個(gè)的結(jié)果。c、 int a=1 , b=2 , c=3, d=4 , e=5;k=a>b ?c: d>e?d: e;求 k 的數(shù)值時(shí)多少?答案為 5(先求 d>e? d: e;結(jié)果為: 5之后求 k=a>b ? c: 5;結(jié)果為: k=5)5) switch 語(yǔ)句:a) 執(zhí)行的流程一定要弄懂!上課時(shí)候詳細(xì)的過程講了,請(qǐng)自己一定弄懂!b)注意有 break 和沒有 break 的差別, 書上的兩個(gè)例子,沒有 break 時(shí)候, 只要有一個(gè)case匹配了,剩下的都要執(zhí)行,有break 則是直接跳出了swiche 語(yǔ)句。 break
25、在 C 語(yǔ)言中就是分手,一刀兩斷的意思。c) switch 只可以和break 一起用,不可以和continue 用。d) switch(x)x:是整型常量,字符型常量,枚舉型數(shù)據(jù)。case 1:.不可以是變量。case 2:.6精選文檔e) switch 是必考題型,請(qǐng)大家一定要完成書上的課后的switch 的習(xí)題。第四章1)三種循環(huán)結(jié)構(gòu):a) for(); while() ;do- while() 三種。b) for 循環(huán)當(dāng)中必須是兩個(gè)分號(hào),千萬(wàn)不要忘記。c)寫程序的時(shí)候一定要注意,循環(huán)一定要有結(jié)束的條件,否則成了死循環(huán)。d) do-while() 循環(huán)的最后一個(gè) while(); 的分號(hào)
26、一定不能夠丟。 (當(dāng)心上機(jī)改錯(cuò)) ,do while 循環(huán)是至少執(zhí)行一次循環(huán)。2) break 和 continue 的差別記憶方法:break:是打破的意思, (破了整個(gè)循環(huán))所以看見break 就退出真?zhèn)€一層循環(huán)。continue: 是繼續(xù)的意思, (繼續(xù)循環(huán)運(yùn)算) ,但是要結(jié)束本次循環(huán),就是循環(huán)體內(nèi)剩下的語(yǔ)句不再執(zhí)行,跳到循環(huán)開始,然后判斷循環(huán)條件,進(jìn)行新一輪的循環(huán)。3)嵌套循環(huán)就是有循環(huán)里面還有循環(huán),這種比較復(fù)雜,要一層一層一步一步耐心的計(jì)算,一般記住兩層是處理二維數(shù)組的。4) while ( c=getchar() ) != n) 和while ( c=getchar() != n)
27、的差別先看 a = 3 != 2和 ( a=3)! =2 的區(qū)別: a=3!=2先判斷 3!=2 的關(guān)系意思為: 3 不等于 2 么?是則 return 1 ;否則 return 0 ;【 1 為真 ,0 為假】結(jié)果返回的是1得到: a=1這個(gè)等號(hào)是賦值,將 1 的值賦給a( a=3)!=2先運(yùn)行 a=3,接著運(yùn)行后面的!=2即括號(hào)的優(yōu)先級(jí)大于!=a=3 表示將 3 賦值給 a再運(yùn)行: 3!=2判斷 3 和 2 是否相等的關(guān)系(! =號(hào)的級(jí)別高于=號(hào) 所以第一個(gè)先計(jì)算3!=2) 第一個(gè) a 的數(shù)值是得到的1;第二個(gè) a的數(shù)值是3。考試注意點(diǎn) : 括號(hào)在這里的重要性。5)每行輸出五個(gè)的寫法:fo
28、r( i=0 ; i<=100 ; i+ ) printf (“ %d”, i );if( ( i+1)%5=0)printf( “ n” );如果 i 是從 1 開始的話,就是if(i%5=0)printf(“ n” );6)如何整除一個(gè)數(shù):i%5=0 表示整除5I%2=0 表示整除2,同時(shí)表示是偶數(shù)!7)輸入 123,輸出 321 逆序輸出數(shù)據(jù)int a=123;while ( i !=0 )7精選文檔printf (“ %d”, i%10 );i=i/10;8)for 只管后面一個(gè)語(yǔ)句:int i=3 ;for ( i=3 ; i<6;i+ ):printf( “#”):請(qǐng)問
29、最終打印幾個(gè)#號(hào)?答案為一個(gè)!9)不停的輸入,直到輸入# 停止輸入!不停的輸入,直到輸入$停止輸入!while( (x=getchar()!= # )while( (x=getchar()!=$ )不停的輸入,直到遇到?停止輸入!while( (x=getchar()!= ? )解說:一定要注意這種給出了條件,然后如何去寫的方法!10) for 循環(huán)和 switch 語(yǔ)句的和在一起考題!11)多次出現(xiàn)的考題:int k=1int k=1 ;while ( - -k );while (k- - );printf (“ %d”,k);printf (“ %d”, k);結(jié)果為 0(第一次循環(huán):測(cè)試
30、的是k=1 ,結(jié)果為 -1(開始時(shí), k=1, 循環(huán)體為空,不做任何事情,k-1,第二次循環(huán)時(shí), k=0,k-1,k=-1,循環(huán)終止,打印k 的值, k=-1 )也即 while(1) ,符合循環(huán)條件,然后k自減變成0,進(jìn)入循環(huán)體(空循環(huán))。第二次循環(huán):測(cè)試的是k=0,也即while(0) ,不符合循環(huán)條件,然后 k 自減變成 -1,跳過循環(huán)體。所以最終輸出的是 -1)第五章1、函數(shù):是具有一定功能的一個(gè)程序塊,是C 語(yǔ)言的基本組成單位。2、函數(shù)不可以嵌套定義。但是可以嵌套調(diào)用。3、函數(shù)名缺省返回值類型,默認(rèn)為int。4、 C 語(yǔ)言由函數(shù)組成,但有且僅有一個(gè)main 函數(shù)!是程序運(yùn)行的開始!5
31、、如何判斷a 是否為質(zhì)數(shù):背誦這個(gè)程序!voidiszhishu ( int a )for ( i=2 ; i<a/2; i+ )if(a%i=0) printf (“不是質(zhì)數(shù)” ) ;printf( “是質(zhì)數(shù)! ”);6、如何求階層:n! 背誦這個(gè)程序!int fun(int n)int p=1;for(i=1;i<=n;i+) p=p*i;return p;7、函數(shù)的參數(shù)可以是常量,變量,表達(dá)式,甚至是函數(shù)調(diào)用 。add( int x , int y ) return x+y ; 8main () int sum ;sum=add( add( 7,8), 9);請(qǐng)問 sum 的
32、結(jié)果是多少?結(jié)果為 248、 函數(shù)的參數(shù),返回?cái)?shù)值(示意圖):精選文檔main()int a = 5,b=6,c;c = add(a,b);printf( “%d”,c);調(diào)用函數(shù)a,b 是實(shí)參整個(gè)函數(shù)得到一個(gè)數(shù)值就是Add 函數(shù)的返回?cái)?shù)值。int add ( int x, int y)int z;z=x+y;return z;被調(diào)用函數(shù)x, y 是形式參數(shù)函數(shù)返回?cái)?shù)值是整型z 就是這個(gè) add 函數(shù)計(jì)算后得到的結(jié)果,就是函數(shù)返回給主程序的返回?cái)?shù)值。程序是在從上往下順序執(zhí)行,當(dāng)碰到了函數(shù)add 后,把 a,b 的數(shù)值穿給調(diào)用函數(shù),程序暫時(shí)中斷等待返回?cái)?shù)值。當(dāng)?shù)玫搅朔祷財(cái)?shù)值后,再順序的往下執(zhí)行9
33、、一定要注意參數(shù)之間的傳遞實(shí)參和形參之間傳數(shù)值,和傳地址的差別。(考試的重點(diǎn))傳數(shù)值的話,形參的變化不會(huì)改變實(shí)參的變化。傳地址的話,形參的變化就會(huì)有可能改變實(shí)參的變化。10、函數(shù)聲明的考查:一定要有:函數(shù)名,函數(shù)的返回類型,函數(shù)的參數(shù)類型。不一定要有:形參的名稱。填空題也可能會(huì)考到!以下是終極難度的考題。打橫線是函數(shù)聲明怎么寫!int *fun ( int a , int b ). 已經(jīng)知道函數(shù)是這樣。這個(gè)函數(shù)的正確的函數(shù)聲明怎么寫?int *fun ( int *a , int *b)這里是函數(shù)聲明的寫法,注意數(shù)組就是指針int *fun ( int a , int b)這種寫法也是正確的i
34、nt *fun ( int b , int c)這種寫法也是正確的,參數(shù)的名稱可以隨便寫int *fun ( int * , int * )這種寫法也是正確的,參數(shù)的名稱可以不寫11、要求掌握的庫(kù)函數(shù):a、庫(kù)函數(shù)是已經(jīng)寫好了函數(shù),放在倉(cāng)庫(kù)中,我們只需要如何去使用就可以了!b、以下這些庫(kù)函數(shù)經(jīng)??嫉?,所以要背誦下來。abs(求絕對(duì)值的函數(shù) )、 sqrt(求 n 的絕對(duì)值。 )、 fabs(求 n 的絕對(duì)值。 )、 pow( 求 n 的 x 次冪并返回 )、 sin() 其中 pow(a, b)是重點(diǎn)。 23 是由 pow(2 , 3)表示的。第六章指針變量的本質(zhì)是用來放地址,而一般的變量是放數(shù)
35、值的。9精選文檔1、 int*p 中*p 和 p 的差別:簡(jiǎn)單說 *p 是數(shù)值, p 是地址!*p 可以當(dāng)做變量來用;* 的作用是取后面地址p 里面的數(shù)值p 是當(dāng)作地址來使用。可以用在scanf 函數(shù)中: scanf(“%d”, p);2、 *p+和 ( *p )+ 的之間的差別: 改錯(cuò)題目中很重要!考試超級(jí)重點(diǎn)*p+ 是 地址會(huì)變化。口訣:取當(dāng)前值,然后再移動(dòng)地址?。?*p ) + 是數(shù)值會(huì)要變化??谠E:取當(dāng)前值,然后再使數(shù)值增加1。例題: int *p,a=1,3,5,7,9;p=a;請(qǐng)問 *p+ 和( *p ) +的數(shù)值分別為多少?*p+ :這個(gè)本身的數(shù)值為1。由于是地址會(huì)增加一,所以指
36、針指向數(shù)值3 了。( *p ) + 這個(gè)本身的數(shù)值為1。由于有個(gè) + 表示數(shù)值會(huì)增加,指針不移動(dòng),但數(shù)值1 由于自加了一次變成了2。3、二級(jí)指針:*p :一級(jí)指針:存放變量的地址。*q :二級(jí)指針:存放一級(jí)指針的地址。??碱}目:int x=7 ;int*p=&x , *q=p ;問你: *p 為多少? *q 為多少? *q 為多少?7p7再問你: *q=&x的寫法可以嗎?不可以,因?yàn)槎?jí)指針只能存放一級(jí)指針的地址。4、三名主義:(考試的重點(diǎn))數(shù)組名:表示第一個(gè)元素的地址。數(shù)組名不可以自加,他是地址常量名。(考了很多次)函數(shù)名:表示該函數(shù)的入口地址。字符串常量名:表示第一個(gè)字符的
37、地址。5、移動(dòng)指針(經(jīng)常加入到考試中其他題目綜合考試)char *s= “ meikanshu”while ( *s ) printf (“ %c”, *s); s+; 這個(gè) s 首先會(huì)指向第一個(gè)字母m 然后通過循環(huán)會(huì)一次打印出一個(gè)字符,s+是地址移動(dòng),打印了一個(gè)字母后,就會(huì)移動(dòng)到下一個(gè)字母!6、指針變量?jī)煞N初始化(一定要看懂)方法一: int a=2, *p=&a; ( 定義的同時(shí)初始化)方法二: int a=2, *p ;( 定義之后初始化)p=&a;7、傳數(shù)值和傳地址(每年必考好多題目)void fun(int a, int b)void fun( int* a, int
38、* b) int t; int t;t=a; a=b; b=t ;t=*a; *a=*b ; *b=t ;main()main() int x=1, y=3, int x=1, y=3,fun( x,y);fun( &x, &y)printf(“ %d, %d”, x, y);printf(“ %d, %d”, x, y);10精選文檔這個(gè)題目答案是1和3。傳數(shù)值, fun 是用變量接受,所以 fun 中的交換不會(huì)影響到 main 中的 x 和 y 。傳數(shù)值,形參的變化不會(huì)影響實(shí)參。這個(gè)題目的答案就是3和 1。傳地址, fun 用指針接受!這個(gè)時(shí)候fun中的交換,就會(huì)影響到ma
39、in 中的 x 和 y。傳地址形參的變化絕大多數(shù)會(huì)影響到實(shí)參!8、函數(shù)返回值是地址,一定注意這個(gè)* 號(hào)(上機(jī)考試重點(diǎn))int* fun (int *a,int *b)可以發(fā)現(xiàn)函數(shù)前面有個(gè)* ,這個(gè)就說明函數(shù)運(yùn)算結(jié)果是地址 if( *a>*b ) return a;return a可以知道返回的是a 地址。else return b;main() int x=7, y=8, *max;max = fun( &x, &y);由于 fun ( &x,&y)的運(yùn)算結(jié)果是地址,所以用max 來接收。printf(“ %d, %d”,)9、考試重要的話語(yǔ):指針變量是存
40、放 地址 的。并且指向哪個(gè)就等價(jià)哪個(gè),所有出現(xiàn) *p 的地方都可以用它等價(jià)的代替。例如: int a=2 , *p=&a;*p=*p+2;( 由于 *p 指向變量 , 所以指向哪個(gè)就等價(jià)哪個(gè),這里*p 等價(jià)于,可以相當(dāng)于是a=a+2)第七章數(shù)組:存放的類型是一致的。多個(gè)數(shù)組元素的地址是連續(xù)的。1、一維數(shù)組的初始化:int a5=1,2,3,4,5;合法int a5=1,2,3, ;合法int a=1,2,3,4,5;合法 ,常考,后面決定前面的大小!int a5=1,2,3,4,5,6;不合法,賦值的個(gè)數(shù)多余數(shù)組的個(gè)數(shù)了2、一維數(shù)組的定義;int a5 ;注意這個(gè)地方有一個(gè)重要考點(diǎn),定
41、義時(shí)數(shù)組的個(gè)數(shù)不是變量一定是常量。int a5合法,最正常的數(shù)組int a1+1合法,個(gè)數(shù)是常量2,是個(gè)算術(shù)表達(dá)式int a1/2+4合法,同樣是算術(shù)表達(dá)式int x=5,int ax;不合法,因?yàn)閭€(gè)數(shù)是x,是個(gè)變量,非法的,define P 5int aP合法, define 后的的 P 是符號(hào)常量,只是長(zhǎng)得像變量3、二維數(shù)組的初始化int a23=1,2,3,4,5,6;合法,很標(biāo)準(zhǔn)的二維的賦值。int a23=1,2,3,4,5, ;合法,后面一個(gè)默認(rèn)為0。int a23=1,2,3, 4,5,6;合法,每行三個(gè)。int a23=1,2,3,4,5;合法,第一行最后一個(gè)默認(rèn)為0。int
42、a23=1,2,3,4,5,6,7;不合法,賦值的個(gè)數(shù)多余數(shù)組的個(gè)數(shù)了。int a3=1,2,3,4,5,6;不合法,不可以缺省行的個(gè)數(shù)。int a2=1,2,3,4,5,6;合法,可以缺省列的個(gè)數(shù)。補(bǔ)充:11精選文檔1)一維數(shù)組的重要概念:對(duì) a10 這個(gè)數(shù)組的討論。、 a 表示數(shù)組名,是第一個(gè)元素的地址,也就是元素a0 的地址。(等價(jià)于 &a )、 a 是地址常量,所以只要出現(xiàn)a+,或者是a=a+2 賦值的都是錯(cuò)誤的。、 a 是一維數(shù)組名,所以它是列指針,也就是說a+1 是跳一列。對(duì) a33 的討論。、 a 表示數(shù)組名,是第一個(gè)元素的地址,也就是元素a00 的地址。、 a 是地址常
43、量,所以只要出現(xiàn)a+,或者是 a=a+2 賦值的都是錯(cuò)誤的。、 a 是二維數(shù)組名,所以它是行指針,也就是說a+1 是跳一行。、a0 、a1 、a2 也都是地址常量, 不可以對(duì)它進(jìn)行賦值操作, 同時(shí)它們都是列指針,a0+1 ,a1+1 , a2+1 都是跳一列。、注意 a 和 a0 、 a1 、 a2 是不同的,它們的基類型是不同的。前者是一行元素,后三者是一列元素。2) 二維數(shù)組做題目的技巧:如果有 a33=1,2,3,4,5,6,7,8,9這樣的題目。步驟一:把他們寫成:第一列第二列第三列a0123 >第一行a1456 >第二行a2789 >第三行步驟二:這樣作題目間很簡(jiǎn)單
44、:*(a0+1) 我們就知道是第一行的第一個(gè)元素往后面跳一列,那么這里就是a01 元素,所以是。*(a1+2) 我們就知道是第二行的第一個(gè)元素往后面跳二列。那么這里就是a12 元素,所以是 6。一定記?。褐灰嵌S數(shù)組的題目,一定是寫成如上的格式,再去做題目,這樣會(huì)比較簡(jiǎn)單。3) 數(shù)組的初始化,一維和二維的,一維可以不寫,二維第二個(gè)一定要寫int a=1 , 2合法。int a4=2,3, 4 合法。但 int a4=2, 3, 4 非法。4) 二維數(shù)組中的行指針int a12 ;其中 a 現(xiàn)在就是一個(gè)行指針,a+1 跳一行數(shù)組元素。搭配( *) p2 指針a0 , a1 現(xiàn)在就是一個(gè)列指針。
45、a0+1 跳一個(gè)數(shù)組元素。搭配*p2 指針數(shù)組使用5) 還有記住脫衣服法則:超級(jí)無(wú)敵重要a2變成* ( a+2)a23 變成* ( a+2) 3 再可以變成*( * ( a+2) +3)這個(gè)思想很重要!其它考試重點(diǎn)文件的復(fù)習(xí)方法:把上課時(shí)候講的文件這一章的題目要做一遍,一定要做,基本上考試的都會(huì)在練習(xí)當(dāng)中。1)字符串的strlen( 求字符串的長(zhǎng)度) 和 strcat(將兩個(gè)char 類型鏈接的函數(shù))和 strcmp(比較2 個(gè)字符串的大?。?和 strcpy(字符串復(fù)制函數(shù))的使用方法一定要記住。他們的參數(shù)都是地址。其中 strcat() 和 strcmp()有兩個(gè)參數(shù)。2) strlen
46、和 sizeof 的區(qū)別也是考試的重點(diǎn);12精選文檔3) define f( x)( x*x ) 和 define f( x) x*x 之間的差別。一定要好好的注意這寫容易錯(cuò)的地方,替換的時(shí)候有括號(hào)和沒有括號(hào)是很大的區(qū)別。int a,b,c,d,e;a=1;b=2;c=6,d=4;e=f(a+b) * f(c+d) ;/ 理論值 e=9*100=900#define f ( x)(x*x )替換結(jié)果為: e=( a+b*a+b)*(c+d*c+d) = 5*34=170#define f ( x) x*x替換結(jié)果為: e=a+b*a+b*c+d*c+d=1+2+12+24+4=43#define f ( x) ( (x)*(x) )替換結(jié)果為: e=( (a+b)*(a+b)*(c+d)*(c+d) )=3*3*10*10=900這個(gè)才是我們想要的結(jié)果!4) int*p ;p = ( int * ) malloc ( 4);p = ( int * ) malloc ( sizeof ( int);以上兩個(gè)等價(jià)當(dāng)心填空題目,malloc 的返回類型是void *6)函數(shù)的遞歸調(diào)用一定要記得有結(jié)束的條件,并且要會(huì)算簡(jiǎn)單的遞歸題目。要會(huì)作遞歸的題目7)結(jié)構(gòu)體和共用體以及鏈表要掌握最
溫馨提示
- 1. 本站所有資源如無(wú)特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025臨時(shí)工作人員勞動(dòng)合同
- 2025煤炭購(gòu)銷合同范本模板
- 2025年中國(guó)臺(tái)面堆肥箱行業(yè)市場(chǎng)前景預(yù)測(cè)及投資價(jià)值評(píng)估分析報(bào)告
- 2025屆高考物理大一輪復(fù)習(xí)課件 第十四章 第76課時(shí) 實(shí)驗(yàn)十七:測(cè)量玻璃的折射率 實(shí)驗(yàn)十八:用雙縫干涉實(shí)驗(yàn)測(cè)量光的波長(zhǎng)
- 2025屆高考物理大一輪復(fù)習(xí)課件 第十一章 第57課時(shí) 磁場(chǎng)及其對(duì)電流的作用
- 2025超市供貨合同范本
- 2025店面租賃合同與經(jīng)營(yíng)權(quán)質(zhì)押協(xié)議范本
- 2025年土地轉(zhuǎn)讓協(xié)議合同范本
- 2025關(guān)于購(gòu)買小麥的合同
- DNA-卟啉兩親雜化體的合成、組裝及其光動(dòng)力治療研究
- 礦山合同轉(zhuǎn)讓協(xié)議書
- 絕經(jīng)后無(wú)癥狀子宮內(nèi)膜增厚診療中國(guó)專家共識(shí)(2024年版)解讀課件
- 設(shè)備委托服務(wù)合同協(xié)議
- 2025湖北省武漢市中考語(yǔ)文模擬檢測(cè)試卷(一模)(含答案)
- 初級(jí)保健按摩師(脊柱按摩師)資格理論必背考試題(附答案)
- 2025屆新高考?xì)v史押題模擬試卷 3套(含答案解析)
- 2025年銀行從業(yè)資格證考試題庫(kù)獲取試題及答案
- 2025年中考時(shí)事政治100題(附答案解析)
- 4-02-02-01 國(guó)家職業(yè)標(biāo)準(zhǔn)客運(yùn)車輛駕駛員 (2025年版)
- 2024北京西城區(qū)四年級(jí)(下)期末語(yǔ)文試題及答案
- 【航線補(bǔ)貼績(jī)效評(píng)估實(shí)證研究-以華夏航空公司為例19000字(論文)】
評(píng)論
0/150
提交評(píng)論