(转载)C++面试宝典2011版 (33)


  1.完成下列程序 
  * 
  *.*. 
  *..*..*.. 
  *...*...*...*... 
  *....*....*....*....*.... 
  *.....*.....*.....*.....*.....*..... 
  *......*......*......*......*......*......*...... 
  *.......*.......*.......*.......*.......*.......*.......*....... 
  #include 
  #define N 8 
  int main() 
  { 
   int i; 
   int j; 
   int k; 
   --------------------------------------------------------- 
   | | 
   | | 
   | | 
   --------------------------------------------------------- 
   return 0; 
  } 
  2.完成程序,实现对数组的降序排序 
  #include 
  void sort( ); 
  int main() 
  { 
   int array[]={45,56,76,234,1,34,23,2,3}; //数字任//意给出 
   sort( ); 
   return 0; 
  } 
  void sort( ) 
  { 
   ____________________________________ 
   | | 
   | | 
   |-----------------------------------------------------| 
  } 
  3.费波那其数列,1,1,2,3,5……编写程序求第十项。可以用递归,也可以用其 
他方法,但要说明你选择的理由。 
  #include 
  int Pheponatch(int); 
  int main() 
  { 
   printf("The 10th is %d",Pheponatch(10)); 
   return 0; 
  } 
  int Pheponatch(int N) 
  { 
  -------------------------------- 
  | | 
  | | 
  -------------------------------- 
  } 
  4.下列程序运行时会崩溃,请找出错误并改正,并且说明原因。 
  #include 
  #include 
  typedef struct{ 
   TNode* left; 
   TNode* right; 
   int value; 
  } TNode; 
  TNode* root=NULL; 
  void append(int N); 
  int main() 
  { 
   append(63); 
   append(45); 
   append(32); 
   append(77); 
   append(96); 
   append(21); 
   append(17); // Again, 数字任意给出 
  } 
  void append(int N) 
  { 
   TNode* NewNode=(TNode *)malloc(sizeof(TNode)); 
   NewNode->value=N; 


   if(root==NULL) 
   { 
   root=NewNode; 
   return; 
   } 
   else 
   { 
   TNode* temp; 
   temp=root; 

   while((N>=temp.value && temp.left!=NULL) || (N !=NULL 
  )) 
   { 
   while(N>=temp.value && temp.left!=NULL) 
   temp=temp.left; 
   while(N    temp=temp.right; 
   } 
   if(N>=temp.value) 
   temp.left=NewNode; 
   else 
   temp.right=NewNode; 
   return; 
   } 
  } 



──────────────────────────────────────── 

55请你分别画出OSI的七层网络结构图和TCP/IP的五层结构图。

应用层:为应用程序提供服务

表示层:处理在两个通信系统中交换信息的表示方式

会话层:负责维护两个结点间会话连接的建立、管理和终止,以及数据交换

传输层:向用户提供可靠的端到端服务。UDP TCP协议。

网络层:通过路由选择算法为分组通过通信子网选择最适当的路径,以及实现拥塞控制、网络互联等功能。数据传输单元是分组。IP地址,路由器,IP协议。

数据链路层:在物理层提供的服务基础上,数据链路层在通信的实体间建立数据链路连接,传输一帧为单位的数据包(,并采用差错控制与流量控制方法,使有差错的物理线路变成无差错的数据链路。)

物理层:传输比特流。传输单元是比特。调制解调器。

56请你详细地解释一下IP协议的定义,在哪个层上面?主要有什么作用?TCP与UDP呢 ?

网络层。

57.请问交换机和路由器各自的实现原理是什么?分别在哪个层次上面实现的?

交换机:数据链路层。路由器:网络层。

58.全局变量和局部变量有什么区别?是怎么实现的?操作系统和编译器是怎么知道的 ?

全局变量的生命周期是整个程序运行的时间,而局部变量的生命周期则是局部函数或过程调用的时间段。其实现是由编译器在编译时采用不同内存分配方法。全局变量在main函数调用后,就开始分配,如果是静态变量则是在main函数前就已经初始化了。而局部变量则是在用户栈中动态分配的(还是建议看编译原理中的活动记录这一块)

59.8086是多少位的系统?在数据总线上是怎么实现的? 


8086微处理器共有4个16位的段寄存器,在寻址内存单元时,用它们直接或间接地存放段地址。

  代码段寄存器CS:存放当前执行的程序的段地址。

  数据段寄存器DS:存放当前执行的程序所用操作数的段地址。

  堆栈段寄存器SS:存放当前执行的程序所用堆栈的段地址。

  附加段寄存器ES:存放当前执行程序中一个辅助数据段的段地址。

由cs:ip构成指令地址,ss:sp构成堆栈的栈顶地址指针。DS和ES用作数据段和附加段的段地址(段起始地址或段值)

8086/8088微处理器的存储器管理

1.地址线(码)与寻址范围:N条地址线     寻址范围=2N

2.8086有20地址线     寻址范围为1MB  由 00000H~FFFFFH

3. 8086微处理器是一个16位结构,用户可用的寄存器均为16位:寻址64KB

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/zgwfdg.html