題目來(lái)源:
1烹看、中興国拇、華為洛史、慧通、英華達(dá)酱吝、微軟亞洲技術(shù)中心等中
外企業(yè)面試題目也殖;
2、C 語(yǔ)言面試寶典(林銳《高質(zhì)量編程第三版》)务热。
說(shuō)明:
1忆嗜、部分C 語(yǔ)言面試題中可能會(huì)參雜部分和C++ 相關(guān)的知
識(shí),為了保持題目的靈活性故保留崎岂,但選題最終還是
會(huì)以C 語(yǔ)言題目為主體捆毫;
2、以上公司的面試題目已成為國(guó)內(nèi)中小型企業(yè)公司出題
模板冲甘;
1绩卤、請(qǐng)?zhí)顚慴ool , float, 指針變量 與“零值”比較的if
語(yǔ)句。
提示:這里“零值”可以是0, 0.0 , FALSE 或者“空指針”
江醇。例如int 變量n 與“零值”比較的if 語(yǔ)句為:
if ( n == 0 )
if ( n != 0 )
以此類推濒憋。
(1)請(qǐng)寫出bool flag 與“零值”比較的if 語(yǔ)句:
【標(biāo)準(zhǔn)答案】if ( flag ) if ( !flag )
100 條經(jīng)典 C語(yǔ)言筆試題目
(2)請(qǐng)寫出float x 與“零值”比較的if 語(yǔ)句:
【標(biāo)準(zhǔn)答案】 const float EPSINON = 0.00001;
if ((x >= - EPSINON) && (x <= EPSINON)
不可將浮點(diǎn)變量用“==” 或“!=” 與數(shù)字比較陶夜,應(yīng)該設(shè)法
轉(zhuǎn)化成“>=” 或“<=” 此類形式凛驮。
100 條經(jīng)典 C語(yǔ)言筆試題目
(3)請(qǐng)寫出char *p 與“零值”比較的if 語(yǔ)句
【標(biāo)準(zhǔn)答案】 if (p == NULL) if (p != NULL)
2、以下為L(zhǎng)inux下的32 位C 程序条辟,請(qǐng)計(jì)算sizeof 的
值黔夭。
char str[] = “Hello” ;
char *p = str ;
i nt n = 10;
請(qǐng)計(jì)算
(1)sizeof (str ) = (2)s i zeof ( p ) =
(3)sizeof ( n ) =
【標(biāo)準(zhǔn)答案】
(1)6、(2)4 羽嫡、(3 )4
(4)void Func ( char str[100])
{
…… ;
}
請(qǐng)計(jì)算sizeof( str ) =
(5)void * p = malloc( 100 );
請(qǐng)計(jì)算sizeof ( p ) =
【標(biāo)準(zhǔn)答案】(4)4纠修、(5)4
4、用變量a 給出下面的定義
e) 一個(gè)有10個(gè)指針的數(shù)組厂僧,該指針是指向一個(gè)整型數(shù)
的;
f) 一個(gè)指向有10個(gè)整型數(shù)數(shù)組的指針;
g) 一個(gè)指向函數(shù)的指針扣草,該函數(shù)有一個(gè)整型參數(shù)并返
回一個(gè)整型數(shù);
h) 一個(gè)有10個(gè)指針的數(shù)組,該指針指向一個(gè)函數(shù),該
函數(shù)有一個(gè)整型參數(shù)并返回一個(gè)整型數(shù);
【標(biāo)準(zhǔn)答案】e)int * a[10]; f)int (a)[10]
g)int (a)(int); h) int (*a[10])(int)
5辰妙、設(shè)有以下說(shuō)明和定義:
typedef u nion {long i; int k[5]; char c;} DATE;
struct data { int cat; DATE cow; double dog;} too;
DATE max;
則語(yǔ)句printf("%d",sizeof(struct date)+sizeof(max)); 的
執(zhí)行結(jié)果是:_____
【標(biāo)準(zhǔn)答案】DATE是一個(gè)union, 變量公用空間. 里面最
大的變量類型是int[5], 占用20個(gè)字節(jié). 所以它的大小是
20
data 是一個(gè)struct, 每個(gè)變量分開(kāi)占用空間. 依次為int4 +
DATE20 + double8 = 32.
所以結(jié)果是20 + 32 = 52.
當(dāng)然... 在某些16位編輯器下, int 可能是2字節(jié),那么結(jié)果
是int2 + DATE10 + double8 = 20
6鹰祸、請(qǐng)問(wèn)以下代碼有什么問(wèn)題:
int main()
{
char a;
char *str=&a;
strcpy(str,"hello");
printf(str);
return 0;
}
【標(biāo)準(zhǔn)答案】沒(méi)有為str分配內(nèi)存空間,將會(huì)發(fā)生異常
問(wèn)題出在將一個(gè)字符串復(fù)制進(jìn)一個(gè)字符變量指針?biāo)?br>
地址密浑。雖然可以正確輸出結(jié)果蛙婴,但因?yàn)樵浇邕M(jìn)行內(nèi)在
讀寫而導(dǎo)致程序崩潰。
7尔破、請(qǐng)問(wèn)以下代碼有什么問(wèn)題:
char* s="AAA";
printf("%s",s);
s[0]='B';
printf("%s",s);
有什么錯(cuò)街图?
【標(biāo)準(zhǔn)答案】"AAA" 是字符串常量。s是指針懒构,指向這個(gè)
字符串常量餐济,所以聲明s的時(shí)候就有問(wèn)題。
cosnt char* s="AAA";
然后又因?yàn)槭浅A康ň纾詫?duì)是s[0] 的賦值操作是不合法
的絮姆。
8、int (s[10])(int) 表示的是什么啊
【標(biāo)準(zhǔn)答案】int (s[10])(int) 函數(shù)指針數(shù)組秩霍,每個(gè)指針
指向一個(gè)int func(intp aram) 的函數(shù)篙悯。
9、c和c++ 中的struct有什么不同铃绒?
【標(biāo)準(zhǔn)答案】c和c++ 中struct的主要區(qū)別是c中的struct
不可以含有成員函數(shù)鸽照,而c++ 中的struct可以。c++ 中
struct和class的主要區(qū)別在于默認(rèn)的存取權(quán)限不同颠悬,
struct默認(rèn)為public 矮燎,而class默認(rèn)為private
10、void getmemory(char *p)
{
p=(char *) malloc(100);
strcpy(p,“hello world”);
}
int main( )
{
char *str=NULL;
getmemory(str);
printf(“%s/n”,str);
free(str);
return 0;
} 會(huì)出現(xiàn)什么問(wèn)題椿疗?
【標(biāo)準(zhǔn)答案】程序崩潰漏峰,getmemory中的malloc 不能返回
動(dòng)態(tài)內(nèi)存,free ()對(duì)str操作很危險(xiǎn)届榄。
11浅乔、char szstr[10];
strcpy(szstr,"0123456789");
產(chǎn)生什么結(jié)果?為什么铝条?
【標(biāo)準(zhǔn)答案】長(zhǎng)度不一樣靖苇,出現(xiàn)段錯(cuò)誤。
100 條經(jīng)典 C語(yǔ)言筆試題目
12班缰、數(shù)組和鏈表的區(qū)別贤壁?
【標(biāo)準(zhǔn)答案】數(shù)組:數(shù)據(jù)順序存儲(chǔ),固定大胁和脾拆;
鏈表:數(shù)據(jù)可以隨機(jī)存儲(chǔ)馒索,大小可動(dòng)態(tài)改變
13、void main()
{
char aa[10];
printf(“%d”,strlen(aa));
}
會(huì)出現(xiàn)什么問(wèn)題名船?打印結(jié)果是是多少绰上?
【標(biāo)準(zhǔn)答案】sizeof()和初不初始化,沒(méi)有關(guān)系渠驼,
strlen()和初始化有關(guān)蜈块,打印結(jié)果值未知。
14迷扇、給定結(jié)構(gòu)struct A
{
char t:4;
char k:4;
unsigned short i:8;
unsigned long m;
}; 問(wèn)sizeof(A) = ?
【標(biāo)準(zhǔn)答案】8
15百揭、struct name1{
char str;
short x;
int num;
} ;求sizeof(name1)?
【標(biāo)準(zhǔn)答案】8
16蜓席、struct name2{
char str;
int num;
short x;
}; 求sizeof(name2)器一?
【標(biāo)準(zhǔn)答案】12
17、程序哪里有錯(cuò)誤
wap( int* p1,int* p2 )
{
int * p;
*p = *p1;
*p1 = *p2;
*p2 = *p;
}
【標(biāo)準(zhǔn)答案】p 為野指針(指向一個(gè)已刪除的對(duì)象或未申請(qǐng)?jiān)L問(wèn)受限內(nèi)存區(qū)域的指針)
19瓮床、(void )ptr 和((void))ptr 的結(jié)果是否相同盹舞?其
中ptr為同一個(gè)指針产镐。
【標(biāo)準(zhǔn)答案】(void )ptr 和((void))ptr 值是相同的
20隘庄、要對(duì)絕對(duì)地址0x100000賦值,我們可以用
(unsigned int)0x100000 = 1234;
那么要是想讓程序跳轉(zhuǎn)到絕對(duì)地址是0x100000去執(zhí)行
癣亚,應(yīng)該怎么做丑掺?
【標(biāo)準(zhǔn)答案】((void ()( ))0x100000 ) ( );
首先要將0x100000強(qiáng)制轉(zhuǎn)換成函數(shù)指針,即:
(void ()())0x100000
然后再調(diào)用它:
((void ()())0x100000)();
22、關(guān)于內(nèi)存的思考題(1)你能看出有什么問(wèn)題述雾?
23街州、關(guān)于內(nèi)存的思考題(2)你能看出有什么問(wèn)題?
25玻孟、關(guān)于內(nèi)存的思考題(3)你能看出有什么問(wèn)題唆缴?
26、關(guān)于內(nèi)存的思考題(4)你能看出有什么問(wèn)題黍翎?
27面徽、關(guān)鍵字volatile有什么含意? 并給出三個(gè)不同的例
子。
【參考答案】一個(gè)定義為volatile的變量是說(shuō)這變量可
能會(huì)被意想不到地改變匣掸,這樣趟紊,編譯器就不會(huì)去假設(shè)
這個(gè)變量的值了。精確地說(shuō)就是碰酝,優(yōu)化器在用到這個(gè)
變量時(shí)必須每次都小心地重新讀取這個(gè)變量的值霎匈,而
不是使用保存在寄存器里的備份。下面是volatile變量
的幾個(gè)例子:
1). 并行設(shè)備的硬件寄存器(如:狀態(tài)寄存器)
2). 一個(gè)中斷服務(wù)子程序中會(huì)訪問(wèn)到的非自動(dòng)變量
(Non-automatic variables)
3). 多線程應(yīng)用中被幾個(gè)任務(wù)共享的變量
28送爸、嵌入式系統(tǒng)經(jīng)常具有要求程序員去訪問(wèn)某特定的
內(nèi)存位置的特點(diǎn)铛嘱。在某工程中暖释,要求設(shè)置一絕對(duì)地址
為0x67a9的整型變量的值為0xaa66。編譯器是一個(gè)純
粹的ANSI編譯器墨吓。寫代碼去完成這一任務(wù)饭入。
【參考答案】這一問(wèn)題測(cè)試你是否知道為了訪問(wèn)一絕對(duì)
地址把一個(gè)整型數(shù)強(qiáng)制轉(zhuǎn)換(typecast )為一指針是合
法的。這一問(wèn)題的實(shí)現(xiàn)方式隨著個(gè)人風(fēng)格不同而不同
肛真。典型的類似代碼如下:
int * ptr;
ptr= (int *)0x67a9;
*ptr = 0xaa55;
29谐丢、頭文件中的ifndef/define/endif 干什么用?
【標(biāo)準(zhǔn)答案】防止該頭文件被重復(fù)引用蚓让。
30乾忱、#include <filename.h> 和#include
“filename.h” 有什么區(qū)別?
【標(biāo)準(zhǔn)答案】對(duì)于#include <filename.h> 历极,編譯器從
標(biāo)準(zhǔn)庫(kù)路徑開(kāi)始搜索filename.h ;
對(duì)于#include “filename.h” 窄瘟,編譯器從用戶的工作路
徑開(kāi)始搜索filename.h 。
31趟卸、const 有什么用途蹄葱?(請(qǐng)至少說(shuō)明兩種)
【標(biāo)準(zhǔn)答案】: (1)可以定義const 常量
(2)const 可以修飾函數(shù)的參數(shù)、返回值锄列,甚至函數(shù)
的定義體图云。被const 修飾的東西都受到強(qiáng)制保護(hù),可
以預(yù)防意外的變動(dòng)邻邮,能提高程序的健壯性竣况。
32、static有什么用途筒严?(請(qǐng)至少說(shuō)明兩種)
【標(biāo)準(zhǔn)答案】
- 限制變量的作用域(static全局變量)丹泉;
- 設(shè)置變量的存儲(chǔ)域(static局部變量)。
33鸭蛙、堆棧溢出一般是由什么原因?qū)е碌模?br> 【標(biāo)準(zhǔn)答案】沒(méi)有回收垃圾資源摹恨。
34、如何引用一個(gè)已經(jīng)定義過(guò)的全局變量娶视?
【標(biāo)準(zhǔn)答案】可以用引用頭文件的方式晒哄,也可以用
extern 關(guān)鍵字,如果用引用頭文件方式來(lái)引用某個(gè)在
頭文件中聲明的全局變理歇万,假定你將那個(gè)變量寫錯(cuò)了
揩晴,那么在編譯期間會(huì)報(bào)錯(cuò),如果你用extern 方式引用
時(shí)贪磺,假定你犯了同樣的錯(cuò)誤硫兰,那么在編譯期間不會(huì)報(bào)
錯(cuò),而在連接期間報(bào)錯(cuò)寒锚。
35劫映、全局變量可不可以定義在可被多個(gè).C 文件包含的
頭文件中违孝?為什么?
【標(biāo)準(zhǔn)答案】可以泳赋,在不同的C 文件中以static形式來(lái)聲
明同名全局變量雌桑。可以在不同的C文件中聲明同名的全
局變量祖今,前提是其中只能有一個(gè)C文件中對(duì)此變量賦初
值校坑,此時(shí)連接不會(huì)出錯(cuò)。
36千诬、隊(duì)列和棧有什么區(qū)別耍目?
【標(biāo)準(zhǔn)答案】隊(duì)列先進(jìn)先出,棧后進(jìn)先出徐绑。
37邪驮、Heap與stack的差別。
【標(biāo)準(zhǔn)答案】Heap是堆傲茄,stack是棧毅访。
Stack的空間由操作系統(tǒng)自動(dòng)分配/釋放,Heap上的空
間手動(dòng)分配/釋放盘榨。
Stack空間有限喻粹,Heap是很大的自由存儲(chǔ)區(qū)
C 中的malloc 函數(shù)分配的內(nèi)存空間即在堆上,C++中對(duì)
應(yīng)的是new 操作符。
程序在編譯期對(duì)變量和函數(shù)分配內(nèi)存都在棧上進(jìn)行,且
程序運(yùn)行過(guò)程中函數(shù)調(diào)用時(shí)參數(shù)的傳遞也在棧上進(jìn)行较曼。
38磷斧、用宏定義寫出swap(x振愿,y)捷犹,即交換兩數(shù)。
【標(biāo)準(zhǔn)答案】
define swap(x, y) (x)=(x)+(y);(y)=(x)–(y);(x)=(x)–(y);
39冕末、寫一個(gè)“標(biāo)準(zhǔn)”宏萍歉,這個(gè)宏輸入兩個(gè)參數(shù)并返回較
小的一個(gè)。
【標(biāo)準(zhǔn)答案】#define Min(X, Y) ((X)>(Y)?(Y):(X))// 結(jié)尾沒(méi)有 ;
40档桃、帶參宏與帶參函數(shù)的區(qū)別(至少說(shuō)出5點(diǎn))枪孩?
【標(biāo)準(zhǔn)答案】
帶參宏 帶參函數(shù)
處理時(shí)間 編譯時(shí) 運(yùn)行時(shí)
參數(shù)類型 無(wú)
需定義
程序長(zhǎng)度 變長(zhǎng)
不變
占用存儲(chǔ)空間 否 是
運(yùn)行時(shí)間 不占運(yùn)行時(shí)間 調(diào)用和返回時(shí)占
41、關(guān)鍵字volatile有什么含意藻肄?
【標(biāo)準(zhǔn)答案】提示編譯器對(duì)象的值可能在編譯器未監(jiān)測(cè)
到的情況下改變蔑舞。
42、int main()
{
int x=3;
printf("%d",x);
return 1;
}
問(wèn)函數(shù)既然不會(huì)被其它函數(shù)調(diào)用嘹屯,為什么要返回1攻询?
【標(biāo)準(zhǔn)答案】mian中,c標(biāo)準(zhǔn)認(rèn)為0表示成功州弟,非0表示
錯(cuò)誤钧栖。具體的值是某中具體出錯(cuò)信息低零。
43、已知一個(gè)數(shù)組tabl e 拯杠,用一個(gè)宏定義掏婶,求出數(shù)據(jù)的
元素個(gè)數(shù)。
【標(biāo)準(zhǔn)答案】
define NTBL(table) (sizeof(table)/sizeof(table[0]))
44潭陪、A.c 和B.c兩個(gè)c文件中使用了兩個(gè)相同名字的
static變量,編譯的時(shí)候會(huì)不會(huì)有問(wèn)題?這兩個(gè)static變量
會(huì)保存到哪里(棧還是堆或者其他的)?
【標(biāo)準(zhǔn)答案】static的全局變量雄妥,表明這個(gè)變量?jī)H在本
模塊中有意義,不會(huì)影響其他模塊依溯。
他們都放在靜態(tài)數(shù)據(jù)區(qū)茎芭,但是編譯器對(duì)他們的命名是
不同的。
如果要使變量在其他模塊也有意義的話誓沸,需要使用
extern 關(guān)鍵字梅桩。
45、static全局變量與普通的全局變量有什么區(qū)別拜隧?
【標(biāo)準(zhǔn)答案】 static全局變量只初使化一次宿百,防止在其
他文件單元中被引用;
46、static局部變量和普通局部變量有什么區(qū)別
【標(biāo)準(zhǔn)答案】static局部變量只被初始化一次洪添,下一次
依據(jù)上一次結(jié)果值垦页;
47、static函數(shù)與普通函數(shù)有什么區(qū)別干奢?
【標(biāo)準(zhǔn)答案】static函數(shù)在內(nèi)存中只有一份痊焊,普通函數(shù)在
每個(gè)被調(diào)用中維持一份拷貝
關(guān)于45-47 的參考文章
全局變量(外部變量)的說(shuō)明之前再冠以static 就構(gòu)成了靜態(tài)的全局變量
。全局變量本身就是靜態(tài)存儲(chǔ)方式忿峻,靜態(tài)全局變量當(dāng)然也是靜態(tài)存儲(chǔ)方
式薄啥。這兩者在存儲(chǔ)方式上并無(wú)不同。這兩者的區(qū)別雖在于非靜態(tài)全局變
量的作用域是整個(gè)源程序逛尚,當(dāng)一個(gè)源程序由多個(gè)源文件組成時(shí)垄惧,非靜態(tài)
的全局變量在各個(gè)源文件中都是有效的。而靜態(tài)全局變量則限制了其作
用域绰寞,即只在定義該變量的源文件內(nèi)有效到逊,在同一源程序的其它源文
件中不能使用它。由于靜態(tài)全局變量的作用域局限于一個(gè)源文件內(nèi)滤钱,只
能為該源文件內(nèi)的函數(shù)公用觉壶,因此可以避免在其它源文件中引起錯(cuò)誤。
從以上分析可以看出件缸,把局部變量改變?yōu)殪o態(tài)變量后是改變了它的存儲(chǔ)
方式即改變了它的生存期铜靶。把全局變量改變?yōu)殪o態(tài)變量后是改變了它的
作用域,限制了它的使用范圍停团。
static函數(shù)與普通函數(shù)作用域不同旷坦。僅在本文件掏熬。只在當(dāng)前源文件中使
用的函數(shù)應(yīng)該說(shuō)明為內(nèi)部函數(shù)(static),內(nèi)部函數(shù)應(yīng)該在當(dāng)前源文件中
說(shuō)明和定義秒梅。對(duì)于可在當(dāng)前源文件以外使用的函數(shù)旗芬,應(yīng)該在一個(gè)頭文件
中說(shuō)明,要使用這些函數(shù)的源文件要包含這個(gè)頭文件捆蜀。
48疮丛、程序的局部變量存在于___ 中,全局變量存在于
____中辆它,動(dòng)態(tài)申請(qǐng)數(shù)據(jù)存在于___ 中誊薄。
【標(biāo)準(zhǔn)答案】程序的局部變量存在于棧(stack) 中,全局
變量存在于靜態(tài)數(shù)據(jù)區(qū)中锰茉,動(dòng)態(tài)申請(qǐng)數(shù)據(jù)存在于堆(
heap)中呢蔫。
49、什么是預(yù)編譯飒筑,何時(shí)需要預(yù)編譯:
【標(biāo)準(zhǔn)答案】1片吊、總是使用不經(jīng)常改動(dòng)的大型代碼體
。
2协屡、程序由多個(gè)模塊組成俏脊,所有模塊都使用一組標(biāo)準(zhǔn)
的包含文件和相同的編譯選項(xiàng)。在這種情況下肤晓,可以
將所有包含文件預(yù)編譯為一個(gè)預(yù)編譯頭爷贫。
50、用兩個(gè)棧實(shí)現(xiàn)一個(gè)隊(duì)列的功能补憾?要求給出算法和
思路漫萄!
【參考答案】設(shè)2個(gè)棧為A,B, 一開(kāi)始均為空.
入隊(duì):
將新元素push入棧A;
出隊(duì):
(1)判斷棧B 是否為空;
(2)如果不為空余蟹,則將棧A中所有元素依次pop 出并
push到棧B卷胯;
(3)將棧B 的棧頂元素pop 出;
51威酒、對(duì)于一個(gè)頻繁使用的短小函數(shù),在C 語(yǔ)言中應(yīng)用什
么實(shí)現(xiàn),在C++ 中應(yīng)用什么實(shí)現(xiàn)?
【標(biāo)準(zhǔn)答案】c用宏定義,c++ 用inline
52挺峡、1. 用預(yù)處理指令#define 聲明一個(gè)常數(shù)葵孤,用以表
明1年中有多少秒(忽略閏年問(wèn)題)
【參考答案】#define SECONDS_PER_YEAR (60 * 60
- 24 * 365)UL
53、Typedef 在C 語(yǔ)言中頻繁用以聲明一個(gè)已經(jīng)存在的
數(shù)據(jù)類型的同義字橱赠。也可以用預(yù)處理器做類似的事尤仍。例
如,思考一下下面的例子:
define dPS struct s *
typedef struct s * tPS;
以上兩種情況的意圖都是要定義dPS 和tPS 作為一個(gè)
指向結(jié)構(gòu)s指針狭姨。哪種方法更好呢宰啦?(如果有的話)為
什么苏遥?
【參考答案】這是一個(gè)非常微妙的問(wèn)題,任何人答對(duì)這個(gè)問(wèn)題(正當(dāng)?shù)脑?br>
因)是應(yīng)當(dāng)被恭喜的赡模。答案是:typedef 更好田炭。思考下面的例子:
dPS p 1,p2;
tPS p3,p4;
第一個(gè)擴(kuò)展為
struct s * p1, p2;
上面的代碼定義p1為一個(gè)指向結(jié)構(gòu)的指,p2為一個(gè)實(shí)際的結(jié)構(gòu)漓柑,這也許
不是你想要的教硫。第二個(gè)例子正確地定義了p3 和p4 兩個(gè)指針。
54辆布、在C++ 程序中調(diào)用被C 編譯器編譯后的函數(shù)瞬矩,
為什么要加extern “C”?
【標(biāo)準(zhǔn)答案】C++ 語(yǔ)言支持函數(shù)重載锋玲,C 語(yǔ)言不支持函
數(shù)重載景用。函數(shù)被C++ 編譯后在庫(kù)中的名字與 C 語(yǔ)言的
不同。假設(shè)某個(gè)函數(shù)的原型為:void foo(int x, int y);
該函數(shù)被C 編譯器編譯后在庫(kù)中的名字為_(kāi)foo 惭蹂,而
C++ 編譯器則會(huì)產(chǎn)生像_foo_int_int之類的名字丛肢。 C++
提供了C 連接交換指定符號(hào)extern“C”來(lái)解決名字匹配
問(wèn)題。
55剿干、請(qǐng)簡(jiǎn)述以下兩個(gè)for 循環(huán)的優(yōu)缺點(diǎn)蜂怎。
【標(biāo)準(zhǔn)答案】
56、語(yǔ)句for( 置尔;1 杠步;) 有什么問(wèn)題?它是什么意思榜轿?
【標(biāo)準(zhǔn)答案】死循環(huán)幽歼,和while(1)相同。
57谬盐、do……while和while……do有什么區(qū)別甸私?
【標(biāo)準(zhǔn)答案】前一個(gè)循環(huán)一遍再判斷,后一個(gè)判斷以后
再循環(huán)飞傀。
58皇型、請(qǐng)寫出下列代碼的輸出內(nèi)容
include <stdio.h>
int main()
{
int a,b,c,d;
a=10;
b=a++;
c=++a;
d=10*a++;
printf("b,c 砸烦,d:%d弃鸦,%d,%d"幢痘,b唬格,c,d );
return 0;
}
【標(biāo)準(zhǔn)答案】10,12购岗,120
59汰聋、unsigned char *p1;
unsigned long *p2;
p1=(unsigned char *)0x801000;
p2=(unsigned long *)0x810000;
請(qǐng)問(wèn)p1+5= ;
p2+5= ;
【標(biāo)準(zhǔn)答案】0x801005、0x810020
60喊积、main()
{
int a[5]={1,2,3,4,5};
int * ptr=(int)(&a+1);
printf(“%d烹困,%d”,(a+1),*(ptr-1));
}
請(qǐng)問(wèn)輸出:
【標(biāo)準(zhǔn)答案】2,5
61、請(qǐng)問(wèn)下面程序有什么錯(cuò)誤?
int a[60][250][1000],i,j,k;
for(k=0;k<=1000;k++)
for(j=0;j<250;j++)
for(i=0;i<60;i++)
a[i][j][k]=0;
【標(biāo)準(zhǔn)答案】把循環(huán)語(yǔ)句內(nèi)外換一下注服。
62韭邓、以下是求一個(gè)數(shù)的平方的程序,請(qǐng)找出錯(cuò)誤:
define SQUARE(a)((a)*(a))
int a=5;
int b;
b=SQUARE(a++);
【標(biāo)準(zhǔn)答案】宏在預(yù)編譯時(shí)會(huì)以替換的形式展開(kāi),僅僅
會(huì)替換溶弟。涉及到宏的地方女淑,不要用++-- ,標(biāo)準(zhǔn)中對(duì)此
沒(méi)有規(guī)定辜御,因此最終結(jié)果將會(huì)依賴于不同的編譯器鸭你。
執(zhí)行程序的答案可能是25、也有可能是36擒权。
63袱巨、#define Max_CB 500
void LmiQueryCSmd(StructMSgCB * pmsg)
{
unsigned char ucCmdNum;
......
for(ucCmdNum=0;ucCmdNum<Max_CB;ucCmdN
um++)
{
......;
}
} 這段代碼執(zhí)行有什么問(wèn)題?
【標(biāo)準(zhǔn)答案】死循環(huán)
unsigned char //無(wú)符號(hào)字符型表示范圍0~255
char // 有符號(hào)字符型 表示范圍-128~127
64碳抄、嵌入式系統(tǒng)中經(jīng)常要用到無(wú)限循環(huán)愉老,你怎么用C
編寫死循環(huán)。
【標(biāo)準(zhǔn)答案】while(1){}或者for(;;)
100 條經(jīng)典 C語(yǔ)言筆試題目
65剖效、程序輸出結(jié)果是嫉入?
【標(biāo)準(zhǔn)答案】8 ,10璧尸,12咒林,14,16
66爷光、
【標(biāo)準(zhǔn)答案】16
67垫竞、int modifyvalue()
{
return(x+=10);
}
int c hangevalue(int x )
{
return(x+=1);
}
void m ain()
{
int x =10;
x++;
changevalue(x);
x++;
modifyvalue();
printf("First output:%dn",x);
x++;
changevalue(x);
printf("Second output:%dn",x);
modifyvalue();
printf("Thirdoutput:%dn",x);
}輸出?
【標(biāo)準(zhǔn)答案】12、13蛀序、13
68欢瞪、不能做switch()的參數(shù)類型是:
【標(biāo)準(zhǔn)答案】switch 的參數(shù)不能為實(shí)型。
69哼拔、請(qǐng)寫出下列代碼的輸出內(nèi)容
#i nclude<stdio.h>
main()
{
int a,b,c,d;
a=10;
b=a++;
c=++a;
d=10*a++;
printf("b引有,c ,d:%d倦逐,%d,%d",b檬姥,c曾我,d );
return 0;
}
【標(biāo)準(zhǔn)答案】10,12健民,120
70抒巢、找出程序的錯(cuò)誤。
【標(biāo)準(zhǔn)答案】
71秉犹、一語(yǔ)句實(shí)現(xiàn)x是否為2 的若干次冪的判斷蛉谜。
【參考答案】 void mai n()
{
i nt a;
scanf(“%d”,&a);
printf(“%c”,(a)&(a-1)?’n’:’y’); // 若是打印y,否則n
}
72崇堵、中斷是嵌入式系統(tǒng)中重要的組成部分型诚,這導(dǎo)致了很多編譯開(kāi)發(fā)商提
供一種擴(kuò)展—讓標(biāo)準(zhǔn)C 支持中斷。具代表事實(shí)是鸳劳,產(chǎn)生了一個(gè)新的關(guān)鍵字
__interrupt 狰贯。下面的代碼就使用了__interrupt 關(guān)鍵字去定義了一個(gè)中斷服
務(wù)子程序(ISR),請(qǐng)?jiān)u論一下這段代碼的赏廓。
__interrupt double compute_area (double radius)
{
double area = PI * radius * radius;
printf(" Area = %f", area);
return area;
}
【參考答案】這個(gè)函數(shù)有太多的錯(cuò)誤了涵紊,以至讓人不知從何說(shuō)起了:
1). ISR 不能返回一個(gè)值。如果你不懂這個(gè)幔摸,那么你不會(huì)被雇用的摸柄。
2). ISR 不能傳遞參數(shù)。如果你沒(méi)有看到這一點(diǎn)既忆,你被雇用的機(jī)會(huì)等同第
一項(xiàng)驱负。
3). 在許多的處理器/編譯器中,浮點(diǎn)一般都是不可重入的尿贫。有些處理器/編
譯器需要讓額處的寄存器入棧电媳,有些處理器/編譯器就是不允許在ISR 中做
浮點(diǎn)運(yùn)算。此外庆亡,ISR 應(yīng)該是短而有效率的匾乓,在ISR 中做浮點(diǎn)運(yùn)算是不明
智的楞黄。
4). 與第三點(diǎn)一脈相承熊锭,printf() 經(jīng)常有重入和性能上的問(wèn)題。如果你丟掉
了第三和第四點(diǎn)了嚎,我不會(huì)太為難你的彰亥。不用說(shuō)咧七,如果你能得到后兩點(diǎn),那
么你的被雇用前景越來(lái)越光明了任斋。
73继阻、下面的代碼輸出是什么,為什么?
void foo(void)
{
unsigned int a = 6;
int b = -20;
(a+b> 6)? puts("> 6") : puts("<= 6");
}
【參考答案】這個(gè)問(wèn)題測(cè)試你是否懂得C 語(yǔ)言中的整數(shù)自動(dòng)轉(zhuǎn)換原則瘟檩,
我發(fā)現(xiàn)有些開(kāi)發(fā)者懂得極少這些東西抹缕。不管如何,這無(wú)符號(hào)整型問(wèn)題的答
案是輸出是“>6” 墨辛。原因是當(dāng)表達(dá)式中存在有符號(hào)類型和無(wú)符號(hào)類型時(shí)所有
的數(shù)都自動(dòng)轉(zhuǎn)換為無(wú)符號(hào)類型卓研。因此-20 變成了一個(gè)非常大的正整數(shù),所
以該表達(dá)式計(jì)算出的結(jié)果大于6 睹簇。這一點(diǎn)對(duì)于應(yīng)當(dāng)頻繁用到無(wú)符號(hào)數(shù)據(jù)類
型的嵌入式系統(tǒng)來(lái)說(shuō)是豐常重要的奏赘。如果你答錯(cuò)了這個(gè)問(wèn)題,你也就到了
得不到這份工作的邊緣太惠。
74磨淌、評(píng)價(jià)下面的代碼片斷:
unsigned int zero = 0;
unsigned int compzero = 0xFFFF;
/*1‘s complement of zero */
【參考答案】對(duì)于一個(gè)int型不是16位的處理器為說(shuō),上面的代碼是不正
確的垛叨。應(yīng)編寫如下:
unsigned int compzero = ~0;
這一問(wèn)題真正能揭露出應(yīng)試者是否懂得處理器字長(zhǎng)的重要性伦糯。在我的經(jīng)
驗(yàn)里,好的嵌入式程序員非常準(zhǔn)確地明白硬件的細(xì)節(jié)和它的局限嗽元,然而
PC機(jī)程序往往把硬件作為一個(gè)無(wú)法避免的煩惱敛纲。
到了這個(gè)階段,應(yīng)試者或者完全垂頭喪氣了或者信心滿滿志在必得剂癌。如
果顯然應(yīng)試者不是很好淤翔,那么這個(gè)測(cè)試就在這里結(jié)束了。但如果顯然應(yīng)
試者做得不錯(cuò)佩谷,那么我就扔出下面的追加問(wèn)題旁壮,這些問(wèn)題是比較難的,
我想僅僅非常優(yōu)秀的應(yīng)試者能做得不錯(cuò)谐檀。提出這些問(wèn)題抡谐,我希望更多看
到應(yīng)試者應(yīng)付問(wèn)題的方法,而不是答案桐猬。不管如何麦撵,你就當(dāng)是這個(gè)娛樂(lè)
吧…
75、下面的代碼片段的輸出是什么溃肪,為什么免胃?
char *ptr;
if ((ptr = (char *)malloc(0)) == NULL)
puts("Gota null pointer");
else
puts("Gota valid pointer");
【參考答案】這個(gè)你可以先大膽猜測(cè)下,然后再用你的
編譯器嘗試著編譯下~~
100 條經(jīng)典 C語(yǔ)言筆試題目
歡迎進(jìn)入C語(yǔ)言程序筆試面試惫撰,編寫程序代碼單元羔沙。
76、編寫strcpy 函數(shù)
已知strcpy 函數(shù)的原型是 char *strcpy(char *strDest,
const char *strSrc);其中strDest是目的字符串厨钻,
strSrc 是源字符串扼雏。
(1)不調(diào)用C++/C 的字符串庫(kù)函數(shù)坚嗜,請(qǐng)編寫函數(shù)
strcpy 。
(2)strcpy 能把 strSrc 的內(nèi)容復(fù)制到strDest呢蛤,為什
么還要char * 類型的返回值惶傻?
77棍郎、寫出二分查找的代碼其障。
【參考答案】 int b inary_search(int* arr, int k ey, int n)
{
int low = 0;
int h igh = n - 1 ;
int m id;
while (low <= high)
{
mid = (high + low) / 2;
if (arr[mid] > k)
high = mid -1 ;
else if (arr[mid] < k)
low = mid + 1;
else
return mid;
}
return -1;
}
78、請(qǐng)編寫一個(gè)C 函數(shù)涂佃,該函數(shù)給出一個(gè)字節(jié)中被置
1 的位的個(gè)數(shù)励翼。
【參考答案】
unsigned int T estAsOne0(char log)
{
int i;
unsigned int num=0, val;
for(i=0; i<8; i++)
{
va l = log >> i; // 移位
val & = 0x01; // 與1 相與
if(val)
num++;
}
return num;
}
79、請(qǐng)編寫一個(gè)C 函數(shù)辜荠,該函數(shù)將給定的一個(gè)字符串
轉(zhuǎn)換成整數(shù)汽抚。
【參考答案】
int Invert(char* str)
{
int num =0;
while(str!='\0')
{
int d igital=str-48;
num=num*10+digital;
str=str+1;
}
return num;
}
80、請(qǐng)編寫一個(gè)C 函數(shù)伯病,該函數(shù)將給定的一個(gè)整數(shù)轉(zhuǎn)
換成字符串造烁。
【參考答案】
void IntToCharChange(int num, char* pval)
{
char strval[100];
int i , j;
int val0 = 0;
int val1 = 0;
val0 = num;
for(i=0; i<100; i++)
{
val1 = val0 % 10; //取余
val0 = val0 / 10; // 取整
strval[i] = val1 + 48; // 數(shù)字—字符
if(val0 < 10)
{
i++;
strval[i] = val0 + 48;
break;
}
}
for(j=0; j<=i; j++) // 倒置
pval[j] = strval[i-j];
pval[j] = '\0';
}
81、實(shí)現(xiàn)strcmp 函數(shù)午笛。
【參考答案】
int m ystrcmp(const c har* str1, const char* str2)
{
assert((str1 != NULL) && (str2 != NULL));
int r et = 0;
while (!(ret = (unsigned char)str1 - * (unsigned char*)str2) && *str2)
{
str1++;
str2++;
}
if (ret > 0)
ret = 1;
else if (ret < 0)
ret = -1;
return ret;
}
82惭蟋、請(qǐng)編寫一個(gè)C 函數(shù),該函數(shù)將一個(gè)字符串逆序药磺。
【參考答案】
void AntitoneValue(cha r* father, char* child)
{
int i ;
char source[100];
int j = 0;
while(father[j]) //放入source 告组,[j] 為長(zhǎng)度
{
source[j] = father[j];
j++;
if(j > 99)
return;
}
source[j] = '\0';
for(i=0; i<j; i++)
child[i] = source[j-i-1]; // 反序
child[i] = '\0';
}
83、請(qǐng)編寫一個(gè)C 函數(shù)癌佩,該函數(shù)在給定的內(nèi)存區(qū)域搜
索給定的字符木缝,并返回該字符所在位置索引值。
【參考答案】
int s earch(char* cpSource, intn , char ch) // 起始地址围辙,搜索長(zhǎng)度我碟,目標(biāo)字符
{
int i;
for(i=0; i<n && *(cpSource+i) != ch; ++i);
return i;
}
84、請(qǐng)編寫一個(gè)C 函數(shù)姚建,該函數(shù)在一個(gè)字符串中找到
可能的最長(zhǎng)的子字符串矫俺,該字符串是由同一字符組成
的。
【參考答案】
int C hildString(charp) // 自己寫
{
char q =p;
int s tringlen=0, i=0,j=1,len=0,maxlen=1;
while(q!=’\0’) //不能用strlen, 求得長(zhǎng)度stringlen
{
Stringlen++;
q++;
}
while( i< String len )
{
if((p+i)==*(p+j)& & j< St ri ngle n )
{
len++; // 統(tǒng)計(jì)子串長(zhǎng)度
i++;
j++;
}
else
{
if(len>maxlen) // 統(tǒng)計(jì)最大子串長(zhǎng)度
{
maxlen=len+1;
len=0;
}
else
len=0;
i++;
j++;
}
}
retu rn ma xlen;
}
85桥胞、華為面試題:怎么判斷鏈表中是否有環(huán)恳守?
【參考答案】答:用兩個(gè)指針來(lái)遍歷這個(gè)單向鏈表,第
一個(gè)指針p1贩虾,每次走一步催烘;第二個(gè)指針p2,每次走兩
步缎罢;當(dāng)p2 指針追上p1的時(shí)候伊群,就表明鏈表當(dāng)中有環(huán)
路了考杉。
int testLinkRing(Link *head)
{
Link t1=head,t2=head;
while( t1->next && t2->next)
{
t1 = t1->next;
if (NULL == (t2 = t2->next->next))
return 0; // 無(wú)環(huán)
if (t1 == t2)
return 1;
}
return 0;
}
86、有一浮點(diǎn)型數(shù)組A, 用C 語(yǔ)言寫一函數(shù)實(shí)現(xiàn)對(duì)浮點(diǎn)
數(shù)組A進(jìn)行降序排序,并輸出結(jié)果,要求要以數(shù)組A 作為
函數(shù)的入口.( 建議用冒泡排序法)
【參考答案】
void BubbleSort(double a rr[], int n)
{
int i舰始,j 崇棠;
int e xchange = 1 ;// 交換標(biāo)志
for(i=1;i<n;i++)
{ // 最多做n-1趟排序
exchange=0 丸卷;// 本趟排序開(kāi)始前枕稀,交換標(biāo)志應(yīng)為假
for(j=n-1;j>=i ;j--) //對(duì)當(dāng)前無(wú)序區(qū)R[i..n]自下向上掃描
if(arr[j+1] > arr [ j])
{// 交換記錄
arr[0]=arr[j+1]谜嫉;//R[0]不是哨兵萎坷,僅做暫存單元
arr[j+1]=arr[j];
arr[j]=arr[0]沐兰;
exchange=1 哆档;// 發(fā)生了交換,故將交換標(biāo)志置為真
}
if(!exchange) // 本趟排序未發(fā)生交換住闯,提前終止算法
return 瓜浸;
} //endfor(外循環(huán))
}
87、實(shí)現(xiàn)雙向鏈表刪除一個(gè)節(jié)點(diǎn)P比原,在節(jié)點(diǎn)P 后插入一
個(gè)節(jié)點(diǎn)插佛,寫出這兩個(gè)函數(shù)。
【參考答案】
// 刪除操作
Status ListDelete_DuL(DuLinkList &L,inti,Ele mType &e)
{
if(!(p=G e tElemP_DuL(L,i))) return ERROR;
e=p->data;
p->prior->next=p->next;
p->next->prior=p->pror;
free(p);
return OK;
}
// 插入操作
Status ListInsert_DuL(DuLinkList &L,inti,ElemType &e)
{
if(!(p=G e tElemP_DuL(L,i)))
return ERROR;
if(!(s=(DuLinkList)malloc(sizeof(DuLNode))))
return ERROR;
s->data=e;
s->pri or =p;
p-> next -> prior =s;
p->next=s;
s->next=p->next->next;
return OK;
}
88春寿、把一個(gè)鏈表反向朗涩。
【參考答案】從第一個(gè)元素開(kāi)始,ps指向他绑改,將他(
ps)指向頭節(jié)點(diǎn)(ps->next = head) 谢床,將ps設(shè)為頭節(jié)點(diǎn)
(head = ps; )操作下一個(gè)元素(ps= pe->next;)等
于是依次將每個(gè)元素翻到原頭節(jié)點(diǎn)前面。
void reverse(test* head)
{
test* pe = head;
test* ps = head->next;
while(ps)
{
pe->next = ps->next;
ps->next = head;
head = ps;
ps = pe->next;
}
}
89厘线、將二維數(shù)組行列元素互換识腿,存到另一個(gè)數(shù)組中。
【參考答案】
include <stdio.h>
main()
{ int a [2][3]={{1,2,3},{4,5,6}};
int b[3][2],i,j;
printf("array a :\n");
for(i=0;i<=1;i++)
{ for(j=0;j<=2;j++)
{ printf("%5d",a[i][j]);
b[j][i]=a[i][j];
}
printf("\n");
}
printf("array b :\n");
for(i=0;i<=2;i++)
{ for(j=0;j<=1;j++)
printf("%5d",b[i][j]);
printf("\n");
}
}
90造壮、輸入一行字符渡讼,統(tǒng)計(jì)其中有多少個(gè)單詞。
【參考答案】
include <stdio.h>
main()
{
char str i ng[81];
int i,num=0,word=0;
char c;
gets(string);
for(i=0;(c=string[i])!='\0';i++)
if(c==' ')
word=0;
else if(word==0)
{
word=1; num++; }
printf("There are %d word s in the line\n",num);
}
91耳璧、寫一個(gè)內(nèi)存拷貝函數(shù),不用任何庫(kù)函數(shù).就是前些時(shí)
候本版討論的那個(gè)問(wèn)題成箫。
【參考答案】
void* m e mcpy(void* pvTo, const void* pvFrom, size_t size)
{
assert((pvTo != NULL) && (pvFrom ! = NULL));
byte* pbTo= pvTo;
byte* pbFrom = pbFrom;
while (size-- > 0)
{
*pbTo++ = *pbFrom++;
}
return pvTo;
}
92、有1旨枯、2蹬昌、3 、4個(gè)數(shù)字攀隔,能組成多少個(gè)互不相同且
無(wú)重復(fù)數(shù)字的三位數(shù)皂贩?都是多少栖榨?
【參考答案】
inc lude "stdio.h"
include "conio.h"
main()
{
int i,j,k;
printf("\n");
for(i=1;i<5;i++) /* 以下為三重循環(huán)/
for(j=1;j<5;j++)
for (k=1;k<5;k++)
{
if (i!=k&&i!=j&&j!=k) / 確保i、j明刷、k三位互不相同*/
pr intf("%d,%d,%d\n",i,j,k);
}
getch();
}
93婴栽、取一個(gè)整數(shù)a從右端開(kāi)始的4~7位。
【參考答案】
main()
{
unsigned a,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()
{
int i,j;
int a [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<i;j++)
a[i][j]=a[i-1][j-1]+a[i-1][j];
for(i=0;i<10;i++)
{
for(j=0;j<=i;j++)
printf("%5d",a[i][j]);
printf("\n");
}
getch();
}
95、實(shí)現(xiàn)strcmp 函數(shù)本冲。
100 條經(jīng)典 C語(yǔ)言筆試題目
96准脂、寫一個(gè)函數(shù),求一個(gè)字符串的長(zhǎng)度檬洞,在main函數(shù)
中輸入字符串,并輸出其長(zhǎng)度沟饥。
【參考答案】
main()
{
intlen;
char *s tr[20];
printf("please input a string:\n");
scanf("%s",str);
len=length(str);
printf("the s tring has %d characters.",len);
getch();
}
length(p)
char p;
{
int n ;
n=0;
while(p!='\0')
{
n++;
p++;
}
return n;
}
97添怔、809??=800??+9??+1 其中??代表的兩位數(shù)
,8?? 的結(jié)果為兩位數(shù),9??的結(jié)果為3位數(shù)贤旷。求??代
表的兩位數(shù)广料,及809??后的結(jié)果。
【參考答案】output(long b,long i)
{
printf("\n%ld/%ld=809%ld+%ld",b,i,i,b%i);
}
main()
{
long int a ,b,i;
a=809;
for(i=10;i<100;i++)
{
b=ia+1;
if(b>=1000&&b<=10000&&8i<100&&9i>=100)
output(b,i);
}
getch();
}
98幼驶、某個(gè)公司采用公用電話傳遞數(shù)據(jù)艾杏,數(shù)據(jù)是四位的整數(shù),在
傳遞過(guò)程中是加密的盅藻,加密規(guī)則如下:每位數(shù)字都加上5, 然后
用和除以10的余數(shù)代替該數(shù)字购桑,再將第一位和第四位交換,第
二位和第三位交換氏淑。
【參考答案】
main()
{
int a ,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--)
prin tf("% d ", a [i]);
getch();
}
99勃蜘、計(jì)算字符串中子串出現(xiàn)的次數(shù)。
【參考答案】
main()
{
char str1[20],str2[20],p1,p2;
int sum=0;
printf("please input two strings\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 假残、有兩個(gè)磁盤文件A和B, 各存放一行字母缭贡,要求把
這兩個(gè)文件中的信息合并(按字母順序排列),輸出
到一個(gè)新文件C 中辉懒。
【參考答案】
100 條經(jīng)典 C語(yǔ)言筆試題目
main()
{
FILE *fp;
in t i,j,n,ni;
char c[160],t,ch;
if((fp=fopen("A","r "))==NULL)
{
printf("file A cannot be opened\n");exit(0);
}
printf("\nA contents are :\n");
for(i=0;(ch=fgetc(fp))!=EOF ; i++)
{
c[i]=ch;pu tchar(c[i]);
}
fclose(fp);
ni=i;
if((fp=fopen("B","r "))==NULL)
{
printf("file B cannot be opened\n");exit(0);
}
printf("\nB contents are :\n");
for(i=0;(ch=fgetc(fp))!=EOF ; i++)
{
c[i]=ch;pu tchar(c[i]);
}
fclose(fp);
n=i;
for(i=0;i<n;i++)
for(j=i+1;j<n;j++)
if(c[i]>c[j]){t=c[i ];c[i]=c[j];c[j]=t;}
printf("\nC file is:\n");
fp =f open("C","w");
for(i=0;i<n;i++){putc(c[i ],fp);putchar(c[i]);}
fclose(fp);
getch();
}