版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
Word第第頁(yè)軟通動(dòng)力C語(yǔ)言筆試題答:能,局部會(huì)屏蔽全局。要用全局變量,需要使用::
局部變量可以與全局變量同名,在函數(shù)內(nèi)引用這個(gè)變量時(shí),會(huì)用到同名的局部變量,而不會(huì)用到全局變量。對(duì)于有些編譯器而言,在同一個(gè)函數(shù)內(nèi)可以定義多個(gè)同名的局部變量,比方在兩個(gè)循環(huán)體內(nèi)都定義一個(gè)同名的局部變量,而那個(gè)局部變量的作用域就在那個(gè)循環(huán)體內(nèi)。
2、如何引用一個(gè)已經(jīng)定義過(guò)的全局變量?
答:extern
可以用引用頭文件的方式,也可以用extern關(guān)鍵字,假如用引用頭文件方式來(lái)引用某個(gè)在頭文件中聲明的全局變理,假定你將那個(gè)變寫錯(cuò)了,那么在編譯期間會(huì)報(bào)錯(cuò),假如你用extern方式引用時(shí),假定你犯了同樣的錯(cuò)誤,那么在編譯期間不會(huì)報(bào)錯(cuò),而在連接期間報(bào)錯(cuò)。
3、全局變量可不行以定義在可被多個(gè).C文件包含的頭文件中?為什么?
答:可以,在不同的C文件中以static形式來(lái)聲明同名全局變量。
可以在不同的C文件中聲明同名的全局變量,前提是其中只能有一個(gè)C文件中對(duì)此變量賦初值,此時(shí)連接不會(huì)出錯(cuò)
4、語(yǔ)句for(;1;)有什么問題?它是什么意思?
答:和while(1)相同。
5、dowhile和whiledo有什么區(qū)分?
答:前一個(gè)循環(huán)一遍再推斷,后一個(gè)推斷以后再循環(huán)
6、請(qǐng)寫出以下代碼的輸出內(nèi)容
#include
main()
{
inta,b,c,d;
a=10;
b=a++;
c=++a;
d=10*a++;
printf(b,c,d:%d,%d,%d,b,c,d);
return0;
}
答:10,12,120
7、static全局變量與一般的全局變量有什么區(qū)分?static局部變量和一般局部變量有什么區(qū)分?static函數(shù)與一般函數(shù)有什么區(qū)分?
全局變量(外部變量)的說(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ò)誤。
從以上分析可以看出,把局部變量轉(zhuǎn)變?yōu)殪o態(tài)變量后是轉(zhuǎn)變了它的存儲(chǔ)方式即轉(zhuǎn)變了它的生存期。把全局變量轉(zhuǎn)變?yōu)殪o態(tài)變量后是轉(zhuǎn)變了它的作用域,限制了它的使用范圍。
static函數(shù)與一般函數(shù)作用域不同。僅在本文件。只在當(dāng)前源文件中使用的`函數(shù)應(yīng)當(dāng)說(shuō)明為內(nèi)部函數(shù)(static),內(nèi)部函數(shù)應(yīng)當(dāng)在當(dāng)前源文件中說(shuō)明和定義。對(duì)于可在當(dāng)前源文件以外使用的函數(shù),應(yīng)當(dāng)在一個(gè)頭文件中說(shuō)明,要使用這些函數(shù)的源文件要包含這個(gè)頭文件
static全局變量與一般的全局變量有什么區(qū)分:static全局變量只初使化一次,防止在其他文件單元中被引用;
static局部變量和一般局部變量有什么區(qū)分:static局部變量只被初始化一次,下一次根據(jù)上一次結(jié)果值;
static函數(shù)與一般函數(shù)有什么區(qū)分:static函數(shù)在內(nèi)存中只有一份,一般函數(shù)在每個(gè)被調(diào)用中維持一份拷貝
8、程序的局部變量存在于(堆棧)中,全局變量存在于(靜態(tài)區(qū))中,動(dòng)態(tài)申請(qǐng)數(shù)據(jù)存在于(堆)中。
9、設(shè)有以下說(shuō)明和定義:
typedefunion{longi;intk[5];charc;}DATE;
structdata{intcat;DATEcow;doubledog;}too;
DATEmax;
則語(yǔ)句printf(%d,sizeof(structdate)+sizeof(max));的執(zhí)行結(jié)果是:___52____
答:DATE是一個(gè)union,變量公用空間.里面最大的變量類型是int[5],占用20個(gè)字節(jié).所以它的大小是20
data是一個(gè)struct,每個(gè)變量分開占用空間.依次為int4+DATE20+double8=32.
所以結(jié)果是20+32=52.
當(dāng)然...在某些16位編輯器下,int可能是2字節(jié),那么結(jié)果是int2+DATE10+double8=20
10、隊(duì)列和棧有什么區(qū)分?
隊(duì)列先進(jìn)先出,棧后進(jìn)先出
11、寫出以下代碼的輸出內(nèi)容
#include
intinc(inta)
{
return(++a);
}
intmulti(int*a,int*b,int*c)
{
return(*c=*a**b);
}
typedefint(FUNC1)(intin);
typedefint(FUNC2)(int*,int*,int*);
voidshow(FUNC2fun,intarg1,int*arg2)
{
INCp=inc;
inttemp=p(arg1);
fun(temp,arg1,arg2);
printf(%d\n,*arg2);
}
main()
{
inta;
show(multi,10,a);
return0;
}
答:110
11、請(qǐng)找出下面代碼中的所以錯(cuò)誤
說(shuō)明:以下代碼是把一個(gè)字符串倒序,如"abcd'倒序后變?yōu)?dcba'
1、#includestring.h
2、main()
3、{
4、char*src=hello,world;
5、char*dest=NULL;
6、intlen=strlen(src);
7、dest=(char*)malloc(len);
8、char*d=dest;
9、char*s=src[len];
10、while(len--!=0)
11、d++=s--;
12、printf(%s,dest);
13、return0;
14、}
答:
方法1:
intmain()
{
char*src=hello,world;
intlen=strlen(src);
char*dest=(char*)malloc(len+1);//要為\0安排一個(gè)空間
char*d=dest;
char*s=src[len-1];//指向最終一個(gè)字符
while(len--!=0)
*d++=*s--;
*d=0;//尾部要加\0
printf(%s\n,dest);
free(dest);//使用完,應(yīng)當(dāng)釋放空間,以免造成內(nèi)存匯泄露
return0;
}
方法2:
#include
#include
main()
{
charstr[]=hello,world;
intlen=strlen(str);
chart;
for(inti=0;i{
t=str[i];
str[i]=str[len-i-1];str[len-i-1]=t;
}
printf(%s,str);
return0;
}
12。對(duì)于一個(gè)頻繁使用的短小函數(shù),在C語(yǔ)言中應(yīng)用什么實(shí)現(xiàn),在C++中應(yīng)用什么實(shí)現(xiàn)?
答案:c用宏定義,c++用inline
13。軟件測(cè)試都有那些種類?
答案:黑盒:針對(duì)系統(tǒng)功能的測(cè)試白合:測(cè)試函數(shù)功能,各函數(shù)接口
14。確定模塊的功能和模塊的接口是在軟件設(shè)計(jì)的那個(gè)隊(duì)段完成的?
答案:概要設(shè)計(jì)階段
15。enumstring
{
x1,
x2,
x3=10,
x4,
x5,
}x;
問x;
答案:取值在0。1。10。11。12中的一個(gè)
16。unsignedchar*p1;
unsignedlong*p2;
p1=(unsignedchar*)0x801000;
p2=(unsignedlong*)0x810000;
請(qǐng)問p1+5=;
p2+5=;
答案:801005;810014。不要遺忘了這個(gè)是16進(jìn)制的數(shù)字,p2要加20變?yōu)?6進(jìn)制就是14
選擇題:
1.Ethternet鏈接到Internet用到以下那個(gè)協(xié)議?
A.HDLC;B.ARP;C.UDP;D.TCP;E.ID
2.屬于網(wǎng)絡(luò)層協(xié)議的是:
A.TCP;B.IP;C.ICMP;D.X.25
3.Windows消息調(diào)度機(jī)制是:
A.指令隊(duì)列;B.指令堆棧;C.消息隊(duì)列;D.消息堆棧;
答案:b,a,c
二找錯(cuò)題:
1.請(qǐng)問下面程序有什么錯(cuò)誤?
inta[60][250][1000],i,j,k;
for(k=0;k=1000;k++)
for(j=0;j250;j++)
for(i=0;i60;i++)
a[i][j][k]=0;
答案:把循環(huán)語(yǔ)句內(nèi)外換一下
2。以下是求一個(gè)數(shù)的平方的程序,請(qǐng)找出錯(cuò)誤:
#defineSQUARE(a)((a)*(a))
inta=5;
intb;
b=SQUARE(a++);
答案:這個(gè)沒有問題,s(a++),就是((a++)(a++))唯一要留意的就是計(jì)算后a=7了
3。typedefunsignedcharBYTE
intexamply_fun(BYTEgt_len;BYTE*gt_code)
{
BYTE*gt_buf;
gt_buf=(BYTE*)MALLOC(Max_GT_Length);
if(gt_lenMax_GT_Length)
{
returnGT_Length_ERROR;
}
}
答案:要釋放內(nèi)存
問答題:
1.IPPhone的原理是什么?
答案:IPV6
2.TCP/IP通信建立的過(guò)程怎樣,端口有什么作用?
答案:三次握手,確定是哪個(gè)應(yīng)用程序使用該協(xié)議
1.用宏定義寫出swap(x,y)
#defineswap(x,y)\
x$denghao$x+y;\
y$denghao$x-y;\
x$denghao$x-y;
2.數(shù)組a[n],存放了1至n-1個(gè)數(shù),其中某個(gè)數(shù)重復(fù)一次。寫一個(gè)函數(shù),找出被重復(fù)的數(shù)字.時(shí)間冗雜度必需為o(n)函數(shù)原型:
intdo_dup(inta[],intn)
3一語(yǔ)句實(shí)現(xiàn)x是否為2的若干次冪的推斷
inti$denghao$512;
coutboolalpha((i(i-1))?false:true)endl;
4.unsignedintintvert(unsignedintx,intp,intn)實(shí)現(xiàn)對(duì)x的進(jìn)行轉(zhuǎn)換,p為起始轉(zhuǎn)化位,n為需要轉(zhuǎn)換的長(zhǎng)度,假設(shè)起始點(diǎn)在右邊.如x$denghao$0b00010001,p$denghao$4,n$denghao$3轉(zhuǎn)換后x$denghao$0b01100001
unsignedintintvert(unsignedintx,intp,intn){
unsignedint_t$denghao$0;
unsignedint_a$denghao$1;
for(inti$denghao$0;in;++i){
_t|$denghao$_a;
_a$denghao$_a1;
}
_t$denghao$_tp;
x^$denghao$_t;
returnx;
}
一.選擇題
1.在關(guān)系數(shù)據(jù)庫(kù)德詢問優(yōu)化中,事先處理文件,如排序、建立索引的目的是:()
A.優(yōu)化表達(dá)式B。削減中間結(jié)束C。擴(kuò)大緩沖數(shù)據(jù)D。削減掃描文件的時(shí)間
2.進(jìn)程是操作系統(tǒng)中的一個(gè)重要概念。進(jìn)程是一個(gè)具有肯定功能的程序在某個(gè)數(shù)據(jù)集合上的一次(A);進(jìn)程是一個(gè)(B)的概念,而程序是一個(gè)(C)的概念;進(jìn)程的最基本狀態(tài)有(D)。在一個(gè)單處理機(jī),若有6個(gè)用戶進(jìn)程,在非管態(tài)的某一時(shí)刻,處于就緒狀態(tài)的用戶進(jìn)程最多有(E)個(gè)。
供選擇的答案
A:(1)單獨(dú)操作(2)關(guān)聯(lián)操作(3)進(jìn)行活動(dòng)(4)并發(fā)活動(dòng)
B:(1)靜態(tài)(2)動(dòng)態(tài)(3)規(guī)律(4)物
C:(1)物理(2)規(guī)律(3)動(dòng)態(tài)(4)靜態(tài)
D:(1)就緒、運(yùn)行、隱藏(2)停止、就緒、運(yùn)行(3)運(yùn)行、就緒、堵塞
(4)就緒、車消、運(yùn)行
E:(1)5(2)6(3)1(4)4
3.有以下幾個(gè)條件成立:()
(1)假如小王是工人,那么小張不是醫(yī)生
(2)或者小李是工人,或者小王是工人
(3)假如小張不是醫(yī)生,那么小趙不是同學(xué)
(4)或者小趙是同學(xué),或者小周不是經(jīng)理
以下哪項(xiàng)假如為真,可得出"小李是工人'的結(jié)論?
(A)小周不是經(jīng)理
(B)小王是工人
(C)小趙不是同學(xué)
(D)小周是經(jīng)理
二.簡(jiǎn)答題
1.下面列舉的是常用的排序方法:直接插入排序,二分法插入排序,起泡排序,快速排序,直接選擇排序,堆排序,歸并排序。試問,哪些排序方法是穩(wěn)定的?
答:(期盼您的高見)
2.對(duì)序列(49,38,65,97,76,27,13,50)采納快速排序法進(jìn)行排序,以序列的第一個(gè)元素為基準(zhǔn)元素得到的劃分結(jié)果是什么?
答:
3.請(qǐng)認(rèn)真閱讀下面的SQL,推斷其是否有錯(cuò)誤,假如有錯(cuò)誤,請(qǐng)說(shuō)明錯(cuò)誤在哪里。
Selectid,name,age,count(*)
Fromtable_name
Wherenamelike"%s%'
Groupbyname
4.請(qǐng)用面對(duì)對(duì)象分析的方法,分析"我用電腦寫程序'這句話的對(duì)象、屬性和方法。
三問答題
電影《達(dá)芬奇密碼》中講到了一個(gè)特別有意思的數(shù)字序列菲波拉契序列。請(qǐng)用任意計(jì)算機(jī)語(yǔ)言實(shí)現(xiàn)一段小程序,該程序在屏幕上輸出1到1000之間的非波拉契序列。
非波拉契序列:1,1,2,3,5,8,13,21,34,
要求:用程序描述核心算法。語(yǔ)言不限。
1.C++中如何阻擋一個(gè)類被實(shí)例化?
2.一般在什么時(shí)候構(gòu)造函數(shù)被聲明成private呢?
3.什么時(shí)候編譯器會(huì)生成默認(rèn)的copyconstructor呢?
4.假如你已經(jīng)寫了一個(gè)構(gòu)造函數(shù),編譯器還會(huì)生成copyconstructor嗎?
5.struct和class有什么區(qū)分?
答:默認(rèn)的訪問級(jí)別不同,struct是public,class是private
6.沒有別的不同了嗎?
7.為什么說(shuō)假如一個(gè)類作為基類,則它的析構(gòu)函數(shù)要聲明成virtual的?
8.inline的函數(shù)和#define有什么區(qū)分?
9.inline是什么意思?
10.那你說(shuō)說(shuō)什么時(shí)候會(huì)真的被inline,什么時(shí)候不會(huì)呢?
11.假如把一個(gè)類的成員函數(shù)寫在類的聲明中是什么意思?
12.public繼承和private繼承有什么架構(gòu)上的區(qū)分?
13.在多繼承的時(shí)候,假如一個(gè)類繼承同時(shí)繼承自classA和classB,而classA和
B中都有一個(gè)函數(shù)叫foo(),如何明確的在子類中指出override哪個(gè)父類的foo()?
14.虛擬繼承的語(yǔ)法是什么?
15.部分模版特例化
1.什么是平衡二叉樹?編寫一個(gè)刪除平衡二叉樹的程序?
2.寫一個(gè)程序,求有向有權(quán)圖兩點(diǎn)之間的最小權(quán)?
3.依據(jù)你的理解,寫出Cstring類的構(gòu)造函數(shù)和析構(gòu)函數(shù)?
4.使用C語(yǔ)言實(shí)現(xiàn)對(duì)ini文件的訪問,使程序可以對(duì)int,double,字符串類進(jìn)行讀寫。
5.nn個(gè)方格(n為任意整數(shù)),定義若兩個(gè)格有公共邊則稱兩個(gè)格相鄰。現(xiàn)將個(gè)格中的N個(gè)格子圖黑,使每個(gè)格子都與黑格子相鄰。試編程,使N最小。
1
#definepi3.14
#defineArea(R)pi*R*R
main()
{
intr1=5,r2=2;
doubles=0;
s=Area(r1-r2);
printf(Theareais%f,s);
}
求結(jié)果
2
函數(shù)intcompare(inta,intb),定義為該函數(shù)的函數(shù)指針P:為_______________
3
#include
voidsub(char*s,intnum)
{
inti,j=num;
chart;
while(j--1)
{
for(i=0;i{
if(s[i]{
t=s[i];
s[i]=s[i+1];
s[i+1]=t;
}
}
}
}
main()
{
char*s=CEAeded;
sub(s,6);
printf(%s\n,s)
}
求結(jié)果
4
交換兩個(gè)變量的值,不使用第三個(gè)變量,即a=3,b=5交換
后b=3,a=5
unsignedchara=3,b=5;
5
#defineN100
voidGetMemory1(char*p)
{
p=(char*)malloc(sizeof(char)*N);
strcpy(p,Haveagoodday!);
}
char*GetMemory2(void)
{
charp[]=Haveagoodday!;
returnp;
}
voidmain(void)
{
char*str1=NULL,*str2=NULL;
GetMemory1(str1);
GetMemory2(str2);
printf(\nstr1:%s,str1);
printf(\nstr2:%s,str2);
6
構(gòu)造N個(gè)結(jié)點(diǎn)的單鏈表返回鏈表頭指針,要求鏈表中各結(jié)點(diǎn)挨次
與結(jié)點(diǎn)數(shù)據(jù)輸入挨次相反,例如輸入1,2,3,4,5,形成的鏈表為
head-54321,補(bǔ)充程序
#defineN10
typedefstructNode
{
intdata;
structNode*next;
}NODE;
intGet_Data(inti);定義省略
Node*Create_u()
{
inti;
NODE*p,*Head=NULL;
for(i=0;i{
VP=NewNODE;
P-Data=Get_Data(i);
________________;
________________;
}
returnHead;
}
7
N個(gè)結(jié)點(diǎn)鏈表,每個(gè)結(jié)點(diǎn)中存放一個(gè)字符,推斷鏈表存放的字符是否
中心對(duì)稱,即abccba或abcba,補(bǔ)充程序
typedefstructNode
{
intdata;
structNode*next;
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 礦山巡查年終總結(jié)范文(3篇)
- 職業(yè)健康監(jiān)護(hù)中的跨區(qū)域協(xié)作機(jī)制
- 職業(yè)健康數(shù)據(jù)挖掘工具開發(fā)與應(yīng)用
- 職業(yè)健康促進(jìn)的成本效益優(yōu)化策略-1
- 高中三年級(jí)歷史《中國(guó)現(xiàn)代教育、文化與科技》
- 職業(yè)健康與生產(chǎn)效率關(guān)聯(lián)性
- 長(zhǎng)沙2025年湖南長(zhǎng)郡雙語(yǔ)星沙學(xué)校公開招聘校聘教師筆試歷年參考題庫(kù)附帶答案詳解
- 金華浙江金華武義經(jīng)濟(jì)開發(fā)區(qū)管理委員會(huì)招聘應(yīng)急消防協(xié)管員筆試歷年參考題庫(kù)附帶答案詳解
- 迪慶2025年云南迪慶香格里拉市小學(xué)教師自主招聘22人筆試歷年參考題庫(kù)附帶答案詳解
- 院感感控督查員培訓(xùn)課件
- 2026年高級(jí)人工智能訓(xùn)練師(三級(jí))理論考試題庫(kù)(附答案)
- 2026北京印鈔有限公司招聘26人筆試備考試題及答案解析
- 2026山西杏花村汾酒集團(tuán)有限責(zé)任公司生產(chǎn)一線技術(shù)工人招聘220人筆試參考題庫(kù)及答案解析
- 百師聯(lián)盟2025-2026學(xué)年高三上學(xué)期1月期末考試俄語(yǔ)試題含答案
- 2026年湖北中煙工業(yè)有限責(zé)任公司招聘169人筆試參考題庫(kù)及答案解析
- 2026年六年級(jí)寒假體育作業(yè)(1月31日-3月1日)
- 干部培訓(xùn)行業(yè)現(xiàn)狀分析報(bào)告
- 東海藥業(yè)校招測(cè)評(píng)題庫(kù)
- 精準(zhǔn)定位式漏水檢測(cè)方案
- 2023氣管插管意外拔管的不良事件分析及改進(jìn)措施
- 2023自動(dòng)啟閉噴水滅火系統(tǒng)技術(shù)規(guī)程
評(píng)論
0/150
提交評(píng)論