當前位置:概念範文網>求職簡歷>筆試題目>

c數據結構算法面試筆試題

筆試題目 閲讀(2.97W)

請問C++的類和C裏面的struct有什麼區別?下面就由本站小編為大家介紹一下c++數據結構算法面試筆試題的文章,歡迎閲讀

c數據結構算法面試筆試題

c++數據結構算法面試筆試題篇1

1請你分別劃劃OSI的七層網絡結構圖,和TCP/IP的五層結構圖?

2請你詳細的解釋一下IP協議的定義,在哪個層上面,主要有什麼作用? TCP與UDP呢? UDP,TCP 在傳輸層,IP在網絡層, TCP/IP是英文Transmission Control Protocol/Internet Protocol的縮寫,意思是"傳輸控制協議/網際協議"。TCP/IP協議組之所以流行,部分原因是因為它可以用在各種各樣的信道和底層協議(例如 T1和X.25、以太網以及RS-232串行接口)之上。確切地説,TCP/IP協議是一組包括TCP協議和IP協議,UDP(User Datagram Protocol)協議、ICMP(Internet Control Message Protocol)協議和其他一些協議的協議組。TCP/IP協議並不完全符合OSI的七層參考模型。傳統的開放式系統互連參考模型,是一種通信協議的7 層抽象的參考模型,其中每一層執行某一特定任務。該模型的目的是使各種硬件在相同的層次上相互通信。這7層是:物理層、數據鏈路層、網路層、傳輸層、話路 層、表示層和應用層。而TCP/IP通訊協議採用了4層的層級結構,每一層都呼叫它的下一層所提供的網絡來完成自己的需求。這4層分別為:

應用層:應用程序間溝通的層,如簡單電子郵件傳輸(SMTP)、文件傳輸協議(FTP)、網絡遠程訪問協議(Telnet)等。

傳輸層:在此層中,它提供了節點間的數據傳送服務,如傳輸控制協議(TCP)、用户數據報協議(UDP)等,TCP和UDP給數據包加入傳輸數據並把它傳輸到下一層中,這一層負責傳送數據,並且確定數據已被送達並接收。

互連網絡層:負責提供基本的數據封包傳送功能,讓每一塊數據包都能夠到達目的主機(但不檢查是否被正確接收),如網際協議(IP)。

網絡接口層:對實際的網絡媒體的管理,定義如何使用實際網絡(如Ethernet、Serial Line等)來傳送數據。

Q3:請問交換機和路由器分別的實現原理是什麼?分別在哪個層次上面實現的?

一 般意義上説交換機是工作在數據鏈路層。但隨着科技的發展,現在有了三層交換機,三層交換機已經擴展到了網絡層。也就是説:它等於“數據鏈路層 + 部分網絡層”。交換機中傳的是幀。通過存儲轉發來實現的。路由器是工作在網絡層。路由器中傳的是IP數據報。主要是選址和路由。

Q4:請問C++的類和C裏面的struct有什麼區別?

結構是一種將數據集合成組的方法,類是一種同時將函數和數據都集合成組的方法。結構和類在表面上的唯一區別是:類中的成員在默認情況下是私有的,而結構中的成員在默認情況下是公用的。

class foo

{

private:

int data1;

public:

void func;

};

可以寫成:

class foo

{

int data1;

public:

void func;

};

因為在類中默認的是私有的,所以關鍵字private就可以不寫了。

如果想用結構完成這個類所作的相同的事,就可以免去關鍵字public,並將公有成員放置在私有成員之前:

struct foo

{

void func;

private:

int data1;

};

Q5:請講一講析構函數和虛函數的用法和作用?

在 JAVA裏沒有象C++中的,所謂的析構函數 ,因為當一個對象不在使用的時候,它會自動被垃圾回收器回收,所以也就用不着析構函數了, 那個finalize 也只有在被垃圾回收器回收,才會被執行,而且很多時候,垃圾回收器並不一定執行,所以它不能當做C++中的,所謂的析構函數使用, 虛函數在JAVA裏也是沒有的,比較象近的應該算是abstract。

Q6:全局變量和局部變量有什麼區別?是怎麼實現的?操作系統和編譯器是怎麼知道的?

1)、全局變量的作用用這個程序塊,而局部變量作用於當前函數

2)、前者在內存中分配在全局數據區,後者分配在棧區

3)、生命週期不同:全局變量隨主程序創建和創建,隨主程序銷燬而銷燬,局部變量在局部函數內部,甚至局部循環體等內部存在,退出就不存在

4)、使用方式不同:通過聲明後全局變量程序的各個部分都可以用到,局部變量只能在局部使用

Q7:一些寄存器的題目,主要是尋址和內存管理等一些知識。

Q8:8086是多少位的系統?在數據總線上是怎麼實現的?

8086微處理器初次發佈時,這塊16位芯片僅包含29000個晶體管,運行速度為5MHz。而當今基於x86架構的奔騰4處理器,已經包含5500萬個晶體管,運行速度提高了600倍以上,高達3.06GHz。

8086是高性能的第三代微處理器,是Intel系列的16位微處理器,它是採用HMOS工藝製造的,內部包含約29,000個晶體管。

8086 有16根數據線和20根地址線,因為可用20位地址,所以可尋址的地址空間達220即1M字節。8086工作時,只要一個5V電源和一相時鐘,時鐘頻率為 5MHz。後來,Intel公司推出的8086-1型微處理器時鐘頻率高達10MHz,8086-2型微處理器時鐘頻率達8MHz。

1、局部變量能否和全局變量重名

答:能,局部會屏蔽全局。要用全局變量,需要使用"::"

局部變量可以與全局變量同名,在函數內引用這個變量時,會用到同名的局部變量,而不會用到全局變量。對於有些編譯器而言,在同一個函數內可以定義多個同名的局部變量,比如在兩個循環體內都定義一個同名的局部變量,而那個局部變量的作用域就在那個循環體內。

2、如何引用一個已經定義過的全局變量

答:extern

可以用引用頭文件的方式,也可以用extern關鍵字,如果用引用頭文件方式來引用某個在頭文件中聲明的全局變理,假定你將那個變寫錯了,那麼在編譯期間會報錯,如果你用extern方式引用時,假定你犯了同樣的錯誤,那麼在編譯期間不會報錯,而在連接期間報錯。

3、全局變量可不可以定義在可被多個.C文件包含的頭文件中 為什麼

答:可以,在不同的C文件中以static形式來聲明同名全局變量。

可以在不同的C文件中聲明同名的全局變量,前提是其中只能有一個C文件中對此變量賦初值,此時連接不會出錯

c++數據結構算法面試筆試題篇2

1、語句for( ;1 ;)有什麼問題 它是什麼意思

答:和while(1)相同。

2、do……while和while……do有什麼區別

答:前一個循環一遍再判斷,後一個判斷以後再循環

3、請寫出下列代碼的輸出內容 以下是引用片段:

#include

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;

}

答:10,12,120

4、static全局變量與普通的全局變量有什麼區別 static局部變量和普通局部變量有什麼區別 static函數與普通函數有什麼區別

全局變量(外部變量)的説明之前再冠以static 就構成了靜態的全局變量。全局變量本身就是靜態存儲方式, 靜態全局變量當然也是靜態存儲方式。 這兩者在存儲方式上並無不同。這兩者的區別雖在於非靜態全局變量的作用域是整個源程序, 當一個源程序由多個源文件組成時,非靜態的全局變量在各個源文件中都是有效的。 而靜態全局變量則限制了其作用域, 即只在定義該變量的源文件內有效, 在同一源程序的其它源文件中不能使用它。由於靜態全局變量的作用域侷限於一個源文件內,只能為該源文件內的函數公用, 因此可以避免在其它源文件中引起錯誤。

從以上分析可以看出, 把局部變量改變為靜態變量後是改變了它的存儲方式即改變了它的生存期。把全局變量改變為靜態變量後是改變了它的作用域, 限制了它的使用範圍。 static函數與普通函數作用域不同。僅在本文件。只在當前源文件中使用的函數應該説明為內部函數(static),內部函數應該在當前源文件中説明和定義。對於可在當前源文件以外使用的函數,應該在一個頭文件中説明,要使用這些函數的源文件要包含這個頭文件

static全局變量與普通的全局變量有什麼區別:static全局變量只初使化一次,防止在其他文件單元中被引用;

static局部變量和普通局部變量有什麼區別:static局部變量只被初始化一次,下一次依據上一次結果值;

static函數與普通函數有什麼區別:static函數在內存中只有一份,普通函數在每個被調用中維持一份拷貝

5、程序的局部變量存在於(堆棧)中,全局變量存在於(靜態區 )中,動態申請數據存在於( 堆)中。

c++數據結構算法面試筆試題篇3

1、隊列和棧有什麼區別

隊列先進先出,棧後進先出

2、寫出下列代碼的輸出內容 以下是引用片段:

#include

int inc(int a)

{

return(++a);

} int multi(int*a,int*b,int*c)

{

return(*c=*a**b); } typedef int(FUNC1)(int in); typedef int(FUNC2) (int*,int*,int*); { INCp=&inc; int temp =p(arg1); fun(&temp,&arg1, arg2); void show(FUNC2 fun,int arg1, int*arg2)

printf("%dn",*arg2);

}

main

{

int a;

show(multi,10,&a);

return 0;

}

答:110