100 條經典C語言筆試題目 - 台部落
文章推薦指數: 80 %
8、int (*s[10])(int) 表示的是什麼啊【標準答案】int (*s[10])(int) 函數指針數組,每個指針指向一個int func(intp aram) 的函數。
9、c和c++ 中的struct ...
請輸入正確的登錄賬號或密碼
註冊
忘記密碼
首頁
c語言
正文
100條經典C語言筆試題目
原創
Lily_9
2019-03-0100:26
題目來源:
1、中興、華爲、慧通、英華達、微軟亞洲技術中心等中
外企業面試題目;
2、C語言面試寶典(林銳《高質量編程第三版》)。
說明:
1、部分C語言面試題中可能會參雜部分和C++相關的知
識,爲了保持題目的靈活性故保留,但選題最終還是
會以C語言題目爲主體;
2、以上公司的面試題目已成爲國內中小型企業公司出題
模板;
3、由於本人的能力有限加上時間倉促,本課件肯定存在
不足之處,懇請各位同學批評指正。
1、請填寫bool,float, 指針變量與“零值”比較的if
語句。
提示:這裏“零值”可以是0,0.0,FALSE 或者“空指針”
。
例如int變量n 與“零值”比較的if 語句爲:
if(n==0)
if(n!=0)
以此類推。
(1)請寫出boolflag 與“零值”比較的if 語句:
【標準答案】if(flag) if(!flag)
100條經典C語言筆試題目
(2)請寫出float x 與“零值”比較的if 語句:
【標準答案】constfloatEPSINON=0.00001;
if((x>=-EPSINON)&&(x<=EPSINON)
不可將浮點變量用“==”或“!=”與數字比較,應該設法
轉化成“>=”或“<=”此類形式。
100條經典C語言筆試題目
(3)請寫出char *p 與“零值”比較的if 語句
【標準答案】if(p==NULL) if(p!=NULL)
2、以下爲Linux下的32位C程序,請計算sizeof的
值。
char str[]=“Hello”;
char *p=str;
int n=10;
請計算
(1)sizeof(str)= (2)sizeof(p)=
(3)sizeof(n)=
【標準答案】
(1)6、(2)4、(3)4
(4)voidFunc(charstr[100])
{
……;
}
請計算sizeof(str)=
(5)void*p=malloc(100);
請計算sizeof(p)=
【標準答案】(4)4、(5)4
4、用變量a給出下面的定義
e)一個有10個指針的數組,該指針是指向一個整型數
的;
f) 一個指向有10個整型數數組的指針;
g)一個指向函數的指針,該函數有一個整型參數並返
回一個整型數;
h)一個有10個指針的數組,該指針指向一個函數,該
函數有一個整型參數並返回一個整型數;
【標準答案】e)int* a[10]; f)int(*a)[10]
g)int(*a)(int); h)int(*a[10])(int)
5、設有以下說明和定義:
typedefunion{longi;intk[5];charc;}DATE;
structdata{intcat;DATEcow;doubledog;}too;
DATEmax;
則語句printf("%d",sizeof(structdate)+sizeof(max));的
執行結果是:_____
【標準答案】DATE是一個union,變量公用空間. 裏面最
大的變量類型是int[5], 佔用20個字節. 所以它的大小是
20
data是一個struct, 每個變量分開佔用空間. 依次爲int4+
DATE20+double8=32.
所以結果是20+32=52.
當然...在某些16位編輯器下,int可能是2字節,那麼結果
是int2+DATE10+double8=20
6、請問以下代碼有什麼問題:
intmain()
{
chara;
char*str=&a;
strcpy(str,"hello");
printf(str);
return0;
}
【標準答案】沒有爲str分配內存空間,將會發生異常
問題出在將一個字符串複製進一個字符變量指針所指
地址。
雖然可以正確輸出結果,但因爲越界進行內在
讀寫而導致程序崩潰。
7、請問以下代碼有什麼問題:
char*s="AAA";
printf("%s",s);
s[0]='B';
printf("%s",s);
有什麼錯?
【標準答案】"AAA"是字符串常量。
s是指針,指向這個
字符串常量,所以聲明s的時候就有問題。
cosntchar*s="AAA";
然後又因爲是常量,所以對是s[0]的賦值操作是不合法
的。
8、int(*s[10])(int) 表示的是什麼啊
【標準答案】int(*s[10])(int) 函數指針數組,每個指針
指向一個intfunc(intparam)的函數。
9、c和c++中的struct有什麼不同?
【標準答案】c和c++中struct的主要區別是c中的struct
不可以含有成員函數,而c++中的struct可以。
c++中
struct和class的主要區別在於默認的存取權限不同,
struct默認爲public,而class默認爲private
10、voidgetmemory(char*p)
{
p=(char*)malloc(100);
strcpy(p,“helloworld”);
}
intmain()
{
char*str=NULL;
getmemory(str);
printf(“%s/n”,str);
free(str);
return0;
}會出現什麼問題?
【標準答案】程序崩潰,getmemory中的malloc不能返回
動態內存,free()對str操作很危險。
11、charszstr[10];
strcpy(szstr,"0123456789");
產生什麼結果?爲什麼?
【標準答案】長度不一樣,出現段錯誤。
100條經典C語言筆試題目
12、數組和鏈表的區別?
【標準答案】數組:數據順序存儲,固定大小;
鏈表:數據可以隨機存儲,大小可動態改變
13、voidmain()
{
charaa[10];
printf(“%d”,strlen(aa));
}
會出現什麼問題?打印結果是是多少?
【標準答案】sizeof()和初不初始化,沒有關係,
strlen()和初始化有關,打印結果值未知。
14、給定結構structA
{
chart:4;
chark:4;
unsignedshorti:8;
unsignedlongm;
};問sizeof(A)=?
【標準答案】8
15、structname1{
charstr;
shortx;
intnum;
};求sizeof(name1)?
【標準答案】8
16、structname2{
charstr;
intnum;
shortx;
};求sizeof(name2)?
【標準答案】12
17、程序哪裏有錯誤
wap(int*p1,int*p2)
{
int*p;
*p=*p1;
*p1=*p2;
*p2=*p;
}
【標準答案】p爲野指針(指向一個已刪除的對象或未申請訪問受限內存區域的指針)
19、(void*)ptr和(*(void**))ptr的結果是否相同?其
中ptr爲同一個指針。
【標準答案】(void*)ptr和(*(void**))ptr值是相同的
20、要對絕對地址0x100000賦值,我們可以用
(unsignedint*)0x100000=1234;
那麼要是想讓程序跳轉到絕對地址是0x100000去執行
,應該怎麼做?
【標準答案】*((void(*)())0x100000)();
首先要將0x100000強制轉換成函數指針,即:
(void(*)())0x100000
然後再調用它:
*((void(*)())0x100000)();
22、關於內存的思考題(1)你能看出有什麼問題?
23、關於內存的思考題(2)你能看出有什麼問題?
25、關於內存的思考題(3)你能看出有什麼問題?
26、關於內存的思考題(4)你能看出有什麼問題?
27、關鍵字volatile有什麼含意?並給出三個不同的例
子。
【參考答案】一個定義爲volatile的變量是說這變量可
能會被意想不到地改變,這樣,編譯器就不會去假設
這個變量的值了。
精確地說就是,優化器在用到這個
變量時必須每次都小心地重新讀取這個變量的值,而
不是使用保存在寄存器裏的備份。
下面是volatile變量
的幾個例子:
1).並行設備的硬件寄存器(如:狀態寄存器)
2).一箇中斷服務子程序中會訪問到的非自動變量
(Non-automaticvariables)
3).多線程應用中被幾個任務共享的變量
28、嵌入式系統經常具有要求程序員去訪問某特定的
內存位置的特點。
在某工程中,要求設置一絕對地址
爲0x67a9的整型變量的值爲0xaa66。
編譯器是一個純
粹的ANSI編譯器。
寫代碼去完成這一任務。
【參考答案】這一問題測試你是否知道爲了訪問一絕對
地址把一個整型數強制轉換(typecast)爲一指針是合
法的。
這一問題的實現方式隨着個人風格不同而不同
。
典型的類似代碼如下:
int*ptr;
ptr= (int*)0x67a9;
*ptr=0xaa55;
29、頭文件中的ifndef/define/endif幹什麼用?
【標準答案】防止該頭文件被重複引用。
30、#include
31、const 有什麼用途?(請至少說明兩種)
【標準答案】:(1)可以定義const 常量
(2)const 可以修飾函數的參數、返回值,甚至函數
的定義體。
被const 修飾的東西都受到強制保護,可
以預防意外的變動,能提高程序的健壯性。
32、static有什麼用途?(請至少說明兩種)
【標準答案】
1.限制變量的作用域(static全局變量);
2.設置變量的存儲域(static局部變量)。
33、堆棧溢出一般是由什麼原因導致的?
【標準答案】沒有回收垃圾資源。
34、如何引用一個已經定義過的全局變量?
【標準答案】可以用引用頭文件的方式,也可以用
extern關鍵字,如果用引用頭文件方式來引用某個在
頭文件中聲明的全局變理,假定你將那個變量寫錯了
,那麼在編譯期間會報錯,如果你用extern方式引用
時,假定你犯了同樣的錯誤,那麼在編譯期間不會報
錯,而在連接期間報錯。
35、全局變量可不可以定義在可被多個.C文件包含的
頭文件中?爲什麼?
【標準答案】可以,在不同的C文件中以static形式來聲
明同名全局變量。
可以在不同的C文件中聲明同名的全
局變量,前提是其中只能有一個C文件中對此變量賦初
值,此時連接不會出錯。
36、隊列和棧有什麼區別?
【標準答案】隊列先進先出,棧後進先出。
37、Heap與stack的差別。
【標準答案】Heap是堆,stack是棧。
Stack的空間由操作系統自動分配/釋放,Heap上的空
間手動分配/釋放。
Stack空間有限,Heap是很大的自由存儲區
C中的malloc函數分配的內存空間即在堆上,C++中對
應的是new操作符。
程序在編譯期對變量和函數分配內存都在棧上進行,且
程序運行過程中函數調用時參數的傳遞也在棧上進行。
38、用宏定義寫出swap(x,y),即交換兩數。
【標準答案】
#defineswap(x,y)(x)=(x)+(y);(y)=(x)–(y);(x)=(x)–(y);
39、寫一個“標準”宏,這個宏輸入兩個參數並返回較
小的一個。
【標準答案】#defineMin(X,Y)((X)>(Y)?(Y):(X))//結尾沒有;
40、帶參宏與帶參函數的區別(至少說出5點)?
【標準答案】
帶參宏 帶參函數
處理時間 編譯時 運行時
參數類型 無 需定義
程序長度 變長 不變
佔用存儲空間 否 是
運行時間 不佔運行時間 調用和返回時佔
41、關鍵字volatile有什麼含意?
【標準答案】提示編譯器對象的值可能在編譯器未監測
到的情況下改變。
42、intmain()
{
intx=3;
printf("%d",x);
return1;
}
問函數既然不會被其它函數調用,爲什麼要返回1?
【標準答案】mian中,c標準認爲0表示成功,非0表示
錯誤。
具體的值是某中具體出錯信息。
43、已知一個數組table,用一個宏定義,求出數據的
元素個數。
【標準答案】
#defineNTBL(table)(sizeof(table)/sizeof(table[0]))
44、A.c和B.c兩個c文件中使用了兩個相同名字的
static變量,編譯的時候會不會有問題?這兩個static變量
會保存到哪裏(棧還是堆或者其他的)?
【標準答案】static的全局變量,表明這個變量僅在本
模塊中有意義,不會影響其他模塊。
他們都放在靜態數據區,但是編譯器對他們的命名是
不同的。
如果要使變量在其他模塊也有意義的話,需要使用
extern關鍵字。
45、static全局變量與普通的全局變量有什麼區別?
【標準答案】static全局變量只初使化一次,防止在其
他文件單元中被引用;
46、static局部變量和普通局部變量有什麼區別
【標準答案】static局部變量只被初始化一次,下一次
依據上一次結果值;
47、static函數與普通函數有什麼區別?
【標準答案】static函數在內存中只有一份,普通函數在
每個被調用中維持一份拷貝
關於45-47的參考文章
全局變量(外部變量)的說明之前再冠以static就構成了靜態的全局變量
。
全局變量本身就是靜態存儲方式,靜態全局變量當然也是靜態存儲方
式。
這兩者在存儲方式上並無不同。
這兩者的區別雖在於非靜態全局變
量的作用域是整個源程序,當一個源程序由多個源文件組成時,非靜態
的全局變量在各個源文件中都是有效的。
而靜態全局變量則限制了其作
用域,即只在定義該變量的源文件內有效,在同一源程序的其它源文
件中不能使用它。
由於靜態全局變量的作用域侷限於一個源文件內,只
能爲該源文件內的函數公用,因此可以避免在其它源文件中引起錯誤。
從以上分析可以看出,把局部變量改變爲靜態變量後是改變了它的存儲
方式即改變了它的生存期。
把全局變量改變爲靜態變量後是改變了它的
作用域,限制了它的使用範圍。
static函數與普通函數作用域不同。
僅在本文件。
只在當前源文件中使
用的函數應該說明爲內部函數(static),內部函數應該在當前源文件中
說明和定義。
對於可在當前源文件以外使用的函數,應該在一個頭文件
中說明,要使用這些函數的源文件要包含這個頭文件。
48、程序的局部變量存在於___中,全局變量存在於
____中,動態申請數據存在於___中。
【標準答案】程序的局部變量存在於棧(stack)中,全局
變量存在於靜態數據區中,動態申請數據存在於堆(
heap)中。
49、什麼是預編譯,何時需要預編譯:
【標準答案】1、總是使用不經常改動的大型代碼體
。
2、程序由多個模塊組成,所有模塊都使用一組標準
的包含文件和相同的編譯選項。
在這種情況下,可以
將所有包含文件預編譯爲一個預編譯頭。
50、用兩個棧實現一個隊列的功能?要求給出算法和
思路!
【參考答案】設2個棧爲A,B,一開始均爲空.
入隊:
將新元素push入棧A;
出隊:
(1)判斷棧B是否爲空;
(2)如果不爲空,則將棧A中所有元素依次pop出並
push到棧B;
(3)將棧B的棧頂元素pop出;
51、對於一個頻繁使用的短小函數,在C語言中應用什
麼實現,在C++中應用什麼實現?
【標準答案】c用宏定義,c++用inline
52、1.用預處理指令#define 聲明一個常數,用以表
明1年中有多少秒(忽略閏年問題)
【參考答案】#defineSECONDS_PER_YEAR(60*60
*24*365)UL
53、Typedef在C語言中頻繁用以聲明一個已經存在的
數據類型的同義字。
也可以用預處理器做類似的事。
例
如,思考一下下面的例子:
#definedPSstructs*
typedefstructs*tPS;
以上兩種情況的意圖都是要定義dPS和tPS作爲一個
指向結構s指針。
哪種方法更好呢?(如果有的話)爲
什麼?
【參考答案】這是一個非常微妙的問題,任何人答對這個問題(正當的原
因)是應當被恭喜的。
答案是:typedef更好。
思考下面的例子:
dPSp1,p2;
tPSp3,p4;
第一個擴展爲
structs*p1,p2;
上面的代碼定義p1爲一個指向結構的指,p2爲一個實際的結構,這也許
不是你想要的。
第二個例子正確地定義了p3和p4兩個指針。
54、在C++ 程序中調用被C編譯器編譯後的函數,
爲什麼要加extern“C”?
【標準答案】C++語言支持函數重載,C語言不支持函
數重載。
函數被C++編譯後在庫中的名字與C語言的
不同。
假設某個函數的原型爲:voidfoo(intx,inty);
該函數被C編譯器編譯後在庫中的名字爲_foo,而
C++編譯器則會產生像_foo_int_int之類的名字。
C++
提供了C連接交換指定符號extern“C”來解決名字匹配
問題。
55、請簡述以下兩個for 循環的優缺點。
【標準答案】
56、語句for( ;1 ;)有什麼問題?它是什麼意思?
【標準答案】死循環,和while(1)相同。
57、do……while和while……do有什麼區別?
【標準答案】前一個循環一遍再判斷,後一個判斷以後
再循環。
58、請寫出下列代碼的輸出內容
#include
62、以下是求一個數的平方的程序,請找出錯誤:
#defineSQUARE(a)((a)*(a))
inta=5;
intb;
b=SQUARE(a++);
【標準答案】宏在預編譯時會以替換的形式展開,僅僅
會替換。
涉及到宏的地方,不要用++--,標準中對此
沒有規定,因此最終結果將會依賴於不同的編譯器。
執行程序的答案可能是25、也有可能是36。
63、#defineMax_CB500
voidLmiQueryCSmd(StructMSgCB*pmsg)
{
unsignedcharucCmdNum;
......
for(ucCmdNum=0;ucCmdNum
【標準答案】
71、一語句實現x是否爲2的若干次冪的判斷。
【參考答案】voidmain()
{
inta;
scanf(“%d”,&a);
printf(“%c”,(a)&(a-1)?’n’:’y’);// 若是打印y,否則n
}
72、中斷是嵌入式系統中重要的組成部分,這導致了很多編譯開發商提
供一種擴展—讓標準C支持中斷。
具代表事實是,產生了一個新的關鍵字
__interrupt。
下面的代碼就使用了__interrupt關鍵字去定義了一箇中斷服
務子程序(ISR),請評論一下這段代碼的。
__interruptdoublecompute_area(doubleradius)
{
doublearea=PI*radius*radius;
printf("Area=%f",area);
returnarea;
}
【參考答案】這個函數有太多的錯誤了,以至讓人不知從何說起了:
1).ISR不能返回一個值。
如果你不懂這個,那麼你不會被僱用的。
2).ISR不能傳遞參數。
如果你沒有看到這一點,你被僱用的機會等同第
一項。
3).在許多的處理器/編譯器中,浮點一般都是不可重入的。
有些處理器/編
譯器需要讓額處的寄存器入棧,有些處理器/編譯器就是不允許在ISR中做
浮點運算。
此外,ISR應該是短而有效率的,在ISR中做浮點運算是不明
智的。
4).與第三點一脈相承,printf()經常有重入和性能上的問題。
如果你丟掉
了第三和第四點,我不會太爲難你的。
不用說,如果你能得到後兩點,那
麼你的被僱用前景越來越光明瞭。
73、下面的代碼輸出是什麼,爲什麼?
voidfoo(void)
{
unsignedinta=6;
intb=-20;
(a+b>6)?puts(">6"):puts("<=6");
}
【參考答案】這個問題測試你是否懂得C語言中的整數自動轉換原則,
我發現有些開發者懂得極少這些東西。
不管如何,這無符號整型問題的答
案是輸出是“>6”。
原因是當表達式中存在有符號類型和無符號類型時所有
的數都自動轉換爲無符號類型。
因此-20變成了一個非常大的正整數,所
以該表達式計算出的結果大於6。
這一點對於應當頻繁用到無符號數據類
型的嵌入式系統來說是豐常重要的。
如果你答錯了這個問題,你也就到了
得不到這份工作的邊緣。
74、評價下面的代碼片斷:
unsignedintzero=0;
unsignedintcompzero= 0xFFFF;
/*1‘scomplementofzero*/
【參考答案】對於一個int型不是16位的處理器爲說,上面的代碼是不正
確的。
應編寫如下:
unsignedintcompzero=~0;
這一問題真正能揭露出應試者是否懂得處理器字長的重要性。
在我的經
驗裏,好的嵌入式程序員非常準確地明白硬件的細節和它的侷限,然而
PC機程序往往把硬件作爲一個無法避免的煩惱。
到了這個階段,應試者或者完全垂頭喪氣了或者信心滿滿志在必得。
如
果顯然應試者不是很好,那麼這個測試就在這裏結束了。
但如果顯然應
試者做得不錯,那麼我就扔出下面的追加問題,這些問題是比較難的,
我想僅僅非常優秀的應試者能做得不錯。
提出這些問題,我希望更多看
到應試者應付問題的方法,而不是答案。
不管如何,你就當是這個娛樂
吧…
75、下面的代碼片段的輸出是什麼,爲什麼?
char*ptr;
if((ptr=(char*)malloc(0))==NULL)
puts("Gotanullpointer");
else
puts("Gotavalidpointer");
【參考答案】這個你可以先大膽猜測下,然後再用你的
編譯器嘗試着編譯下~~
100條經典C語言筆試題目
歡迎進入C語言程序筆試面試,編寫程序代碼單元。
76、編寫strcpy函數
已知strcpy函數的原型是char*strcpy(char*strDest,
constchar*strSrc);其中strDest是目的字符串,
strSrc是源字符串。
(1)不調用C++/C的字符串庫函數,請編寫函數
strcpy。
(2)strcpy能把strSrc的內容複製到strDest,爲什
麼還要char* 類型的返回值?
77、寫出二分查找的代碼。
【參考答案】intbinary_search(int*arr,intkey,intn)
{
intlow= 0;
inthigh=n-1;
intmid;
while(low<=high)
{
mid=(high+low)/2;
if(arr[mid]>k)
high=mid-1;
elseif(arr[mid]
【參考答案】
intInvert(char*str)
{
intnum=0;
while(*str!='\0')
{
intdigital=*str-48;
num=num*10+digital;
str=str+1;
}
returnnum;
}
80、請編寫一個C函數,該函數將給定的一個整數轉
換成字符串。
【參考答案】
voidIntToCharChange(intnum, char*pval)
{
charstrval[100];
inti,j;
intval0=0;
intval1=0;
val0=num;
for(i=0;i<100;i++)
{
val1=val0%10;//取餘
val0=val0/10;//取整
strval[i]=val1+48; //數字—字符
if(val0<10)
{
i++;
strval[i]=val0+48;
break;
}
}
for(j=0;j<=i;j++) //倒置
pval[j]=strval[i-j];
pval[j]='\0';
}
81、實現strcmp函數。
【參考答案】
intmystrcmp(constchar*str1,constchar*str2)
{
assert((str1!=NULL)&&(str2!=NULL));
intret=0;
while(!(ret=*(unsignedchar*)str1-*(unsignedchar*)str2)&&*str2)
{
str1++;
str2++;
}
if(ret>0)
ret=1;
elseif(ret<0)
ret=-1;
returnret;
}
82、請編寫一個C函數,該函數將一個字符串逆序。
【參考答案】
voidAntitoneValue(char*father,char*child)
{
inti;
charsource[100];
intj=0;
while(father[j])//放入source,[j]爲長度
{
source[j]=father[j];
j++;
if(j>99)
return;
}
source[j]='\0';
for(i=0;i
inttestLinkRing(Link*head)
{
Link*t1=head,*t2=head;
while(t1->next&&t2->next)
{
t1=t1->next;
if(NULL==(t2=t2->next->next))
return0;//無環
if(t1==t2)
return1;
}
return0;
}
86、有一浮點型數組A,用C語言寫一函數實現對浮點
數組A進行降序排序,並輸出結果,要求要以數組A作爲
函數的入口.(建議用冒泡排序法)
【參考答案】
voidBubbleSort(doublearr[],intn)
{
inti,j;
intexchange=1;//交換標誌
for(i=1;i
【參考答案】
//刪除操作
StatusListDelete_DuL(DuLinkList&L,inti,ElemType&e)
{
if(!(p=GetElemP_DuL(L,i)))returnERROR;
e=p->data;
p->prior->next=p->next;
p->next->prior=p->pror;
free(p);
returnOK;
}
//插入操作
StatusListInsert_DuL(DuLinkList&L,inti,ElemType&e)
{
if(!(p=GetElemP_DuL(L,i)))
returnERROR;
if(!(s=(DuLinkList)malloc(sizeof(DuLNode))))
returnERROR;
s->data=e;
s->prior=p;
p->next->prior=s;
p->next=s;
s->next=p->next->next;
returnOK;
}
88、把一個鏈表反向。
【參考答案】從第一個元素開始,ps指向他,將他(
ps)指向頭節點(ps->next=head),將ps設爲頭節點
(head=ps;)操作下一個元素(ps=pe->next;)等
於是依次將每個元素翻到原頭節點前面。
voidreverse(test*head)
{
test*pe=head;
test*ps=head->next;
while(ps)
{
pe->next=ps->next;
ps->next=head;
head=ps;
ps= pe->next;
}
}
89、將二維數組行列元素互換,存到另一個數組中。
【參考答案】
#include
【參考答案】
#include
【參考答案】
void*memcpy(void*pvTo,constvoid*pvFrom,size_tsize)
{
assert((pvTo!=NULL)&&(pvFrom!=NULL));
byte*pbTo=pvTo;
byte*pbFrom=pbFrom;
while(size--> 0)
{
*pbTo++=*pbFrom++;
}
returnpvTo;
}
92、有1、2、3、4個數字,能組成多少個互不相同且
無重複數字的三位數?都是多少?
【參考答案】
#include "stdio.h"
#include"conio.h"
main()
{
inti,j,k;
printf("\n");
for(i=1;i<5;i++)/*以下爲三重循環*/
for(j=1;j<5;j++)
for(k=1;k<5;k++)
{
if(i!=k&&i!=j&&j!=k)/*確保i、j、k三位互不相同*/
printf("%d,%d,%d\n",i,j,k);
}
getch();
}
93、取一個整數a從右端開始的4~7位。
【參考答案】
main()
{
unsigneda,b,c,d;
scanf("%o",&a);
b=a>>4;
c=~(~0<<4);
d=b&c;
printf("%o\n%o\n",a,d);
}
94、打印出楊輝三角形(要求打印出10行如下圖)。
【參考答案】
main()
{
inti,j;
inta[10][10];
printf("\n");
for(i=0;i<10;i++)
{
a[i][0]=1;
a[i][i]=1;
}
for(i=2;i<10;i++)
for(j=1;j=1000&&b<=10000&&8*i<100&&9*i>=100)
output(b,i);
}
getch();
}
98、某個公司採用公用電話傳遞數據,數據是四位的整數,在
傳遞過程中是加密的,加密規則如下:每位數字都加上5,然後
用和除以10的餘數代替該數字,再將第一位和第四位交換,第
二位和第三位交換。
【參考答案】
main()
{
inta,i,aa[4],t;
scanf("%d",&a);
aa[0]=a%10;
aa[1]=a%100/10;
aa[2]=a%1000/100;
aa[3]=a/1000;
for(i=0;i<=3;i++)
{
aa[i]+=5;
aa[i]%=10;
}
for(i=0;i<=3/2;i++)
{
t=aa[i];
aa[i]=aa[3-i];
aa[3-i]=t;
}
for(i=3;i>=0;i--)
printf("%d",a[i]);
getch();
}
99、計算字符串中子串出現的次數。
【參考答案】
main()
{
charstr1[20],str2[20],*p1,*p2;
intsum=0;
printf("pleaseinputtwostrings\n");
scanf("%s%s",str1,str2);
p1=str1;p2=str2;
while(*p1!='\0')
{
if(*p1==*p2)
{
while(*p1==*p2&&*p2!='\0')
{
p1++;
p2++;
}
}
else
p1++;
if(*p2=='\0')
sum++;
p2=str2;
}
printf("%d",sum);
getch();
}
100、有兩個磁盤文件A和B,各存放一行字母,要求把
這兩個文件中的信息合併(按字母順序排列),輸出
到一個新文件C中。
【參考答案】
main()
{
FILE*fp;
inti,j,n,ni;
charc[160],t,ch;
if((fp=fopen("A","r"))==NULL)
{
printf("fileAcannot beopened\n");exit(0);
}
printf("\nAcontentsare:\n");
for(i=0;(ch=fgetc(fp))!=EOF;i++)
{
c[i]=ch;putchar(c[i]);
}
fclose(fp);
ni=i;
if((fp=fopen("B","r"))==NULL)
{
printf("fileBcannot beopened\n");exit(0);
}
printf("\nBcontentsare:\n");
for(i=0;(ch=fgetc(fp))!=EOF;i++)
{
c[i]=ch;putchar(c[i]);
}
fclose(fp);
n=i;
for(i=0;i
延伸文章資訊
- 1C/C++ 筆試、面試題目大彙總 - 日日新聞
- 2經典C語言筆試題目 - 程式人生
100 條經典C語言筆試題目 (3)請寫出char *p 與“零值”比較的if 語句 【標準答案】 if (p == NULL) if (p != NULL) 2、以下為Linux下的32 位C...
- 3C面試考題
註:C 語言之父明確表示C 語言只有call by value。 void swap (int c , int d){ int temp=c; c=d; d=temp; } int main()...
- 4100 條經典C語言筆試題目 - 台部落
8、int (*s[10])(int) 表示的是什麼啊【標準答案】int (*s[10])(int) 函數指針數組,每個指針指向一個int func(intp aram) 的函數。 9、c和c+...
- 5100 條經典C語言筆試題目(轉) - 程式人生
2、C 語言面試寶典(林銳《高質量程式設計第三版》)。 說明: 1、部分C 語言面試題中可能會參雜部分和C++ 相關的知 識 ...