著名企业cc数据结构算法面试笔试题.docx
《著名企业cc数据结构算法面试笔试题.docx》由会员分享,可在线阅读,更多相关《著名企业cc数据结构算法面试笔试题.docx(25页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
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协议,UDPUser Datagram Protocol协议、IC
2、MPInternet Control Message Protocol协议和其他一些协议的协议组。TCP/IP协议并不完全符合OSI的七层参考模型。传统的开放式系统互连参考模型,是一种通信协议的7 层抽象的参考模型,其中每一层执行某一特定任务。该模型的目的是使各种硬件在一样的层次上相互通信。这7层是:物理层、数据链路层、网路层、传输层、话路 层、表示层和应用层。而TCP/IP通讯协议采用了4层的层级构造,每一层都呼叫它的下一层所提供的网络来完成自己的需求。这4层分别为:应用层:应用程序间沟通的层,如简单电子邮件传输SMTP、文件传输协议FTP、网络远程访问协议Telnet等。传输层:在此层中,
3、它提供了节点间的数据传送效劳,如传输控制协议TCP、用户数据报协议UDP等,TCP和UDP给数据包参加传输数据并把它传输到下一层中,这一层负责传送数据,并且确定数据已被送达并接收。互连网络层:负责提供根本的数据封包传送功能,让每一块数据包都能够到达目的主机但不检查是否被正确接收,如网际协议IP。网络接口层:对实际的网络媒体的管理,定义如何使用实际网络如Ethernet、Serial Line等来传送数据。Q3:请问交换机和路由器分别的实现原理是什么?分别在哪个层次上面实现的?一 般意义上说交换机是工作在数据链路层。但随着科技的开展,现在有了三层交换机,三层交换机已经扩展到了网络层。也就是说:它
4、等于“数据链路层 + 局部网络层。交换机中传的是帧。通过存储转发来实现的。路由器是工作在网络层。路由器中传的是IP数据报。主要是选址和路由。Q4:请问C+的类和C里面的struct有什么区别?构造是一种将数据集合成组的方法,类是一种同时将函数和数据都集合成组的方法。构造和类在外表上的唯一区别是:类中的成员在默认情况下是私有的,而构造中的成员在默认情况下是公用的。 class foo private: int data1; public: void func(); ; 可以写成: class foo int data1; public: void func(); ; 因为在类中默认的是私有的,所
5、以关键字private就可以不写了。 如果想用构造完成这个类所作的一样的事,就可以免去关键字public,并将公有成员放置在私有成员之前: struct foo void func(); private: int data1; ;Q5:请讲一讲析构函数和虚函数的用法和作用?在 JAVA里没有象C+中的,所谓的析构函数 ,因为当一个对象不在使用的时候,它会自动被垃圾回收器回收,所以也就用不着析构函数了, 那个finalize 也只有在被垃圾回收器回收,才会被执行,而且很多时候,垃圾回收器并不一定执行,所以它不能当做C+中的,所谓的析构函数使用, 虚函数在JAVA里也是没有的,比拟象近的应该算是a
6、bstract。Q6:全局变量和局部变量有什么区别?是怎么实现的?操作系统和编译器是怎么知道的?1、全局变量的作用用这个程序块,而局部变量作用于当前函数2、前者在内存中分配在全局数据区,后者分配在栈区3、生命周期不同:全局变量随主程序创立和创立,随主程序销毁而销毁,局部变量在局部函数内部,甚至局部循环体等内部存在,退出就不存在4、使用方式不同:通过声明后全局变量程序的各个局部都可以用到,局部变量只能在局部使用Q7:一些存放器的题目,主要是寻址和内存管理等一些知识。Q8:8086是多少位的系统?在数据总线上是怎么实现的?8086微处理器初次发布时,这块16位芯片仅包含29000个晶体管,运行速度
7、为5。而当今基于86架构的奔腾4处理器,已经包含5500万个晶体管,运行速度提高了600倍以上,高达306。8086是高性能的第三代微处理器,是Intel系列的16位微处理器,它是采用HMOS工艺制造的,内部包含约29,000个晶体管。 8086 有16根数据线和20根地址线,因为可用20位地址,所以可寻址的地址空间达220即1M字节。8086工作时,只要一个5V电源和一相时钟,时钟频率为 5MHz。后来,Intel公司推出的8086-1型微处理器时钟频率高达10MHz,8086-2型微处理器时钟频率达8MHz。1、局部变量能否和全局变量重名 答:能,局部会屏蔽全局。要用全局变量,需要使用:局
8、部变量可以及全局变量同名,在函数内引用这个变量时,会用到同名的局部变量,而不会用到全局变量。对于有些编译器而言,在同一个函数内可以定义多个同名的局部变量,比方在两个循环体内都定义一个同名的局部变量,而那个局部变量的作用域就在那个循环体内。2、如何引用一个已经定义过的全局变量 答:extern可以用引用头文件的方式,也可以用extern关键字,如果用引用头文件方式来引用某个在头文件中声明的全局变理,假定你将那个变写错了,那么在编译期间会报错,如果你用extern方式引用时,假定你犯了同样的错误,那么在编译期间不会报错,而在连接期间报错。3、全局变量可不可以定义在可被多个.C文件包含的头文件中 为
9、什么 答:可以,在不同的C文件中以static形式来声明同名全局变量。可以在不同的C文件中声明同名的全局变量,前提是其中只能有一个C文件中对此变量赋初值,此时连接不会出错4、语句for( ;1 ;)有什么问题 它是什么意思 答:和while(1)一样。5、dowhile和whiledo有什么区别 答:前一个循环一遍再判断,后一个判断以后再循环6、请写出以下代码的输出内容以下是引用片段: #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,1
10、207、static全局变量及普通的全局变量有什么区别 static局部变量和普通局部变量有什么区别 static函数及普通函数有什么区别 全局变量(外部变量)的说明之前再冠以static 就构成了静态的全局变量。全局变量本身就是静态存储方式, 静态全局变量当然也是静态存储方式。 这两者在存储方式上并无不同。这两者的区别虽在于非静态全局变量的作用域是整个源程序, 当一个源程序由多个源文件组成时,非静态的全局变量在各个源文件中都是有效的。 而静态全局变量那么限制了其作用域, 即只在定义该变量的源文件内有效, 在同一源程序的其它源文件中不能使用它。由于静态全局变量的作用域局限于一个源文件内,只能为
11、该源文件内的函数公用, 因此可以防止在其它源文件中引起错误。从以上分析可以看出, 把局部变量改变为静态变量后是改变了它的存储方式即改变了它的生存期。把全局变量改变为静态变量后是改变了它的作用域, 限制了它的使用范围。static函数及普通函数作用域不同。仅在本文件。只在当前源文件中使用的函数应该说明为内部函数(static),内部函数应该在当前源文件中说明和定义。对于可在当前源文件以外使用的函数,应该在一个头文件中说明,要使用这些函数的源文件要包含这个头文件static全局变量及普通的全局变量有什么区别:static全局变量只初使化一次,防止在其他文件单元中被引用;static局部变量和普通局
12、部变量有什么区别:static局部变量只被初始化一次,下一次依据上一次结果值;static函数及普通函数有什么区别:static函数在内存中只有一份,普通函数在每个被调用中维持一份拷贝8、程序的局部变量存在于(堆栈)中,全局变量存在于(静态区 )中,动态申请数据存在于( 堆)中。9、设有以下说明和定义:typedef union long i; int k5; char c; DATE;struct data int cat; DATE cow; double dog; too;DATE max;那么语句 printf(%d,sizeof(struct date)+sizeof(max);的执
13、行结果是:_52_答:DATE是一个union, 变量公用空间. 里面最大的变量类型是int5, 占用20个字节. 所以它的大小是20data是一个struct, 每个变量分开占用空间. 依次为int4 + DATE20 + double8 = 32.所以结果是 20 + 32 = 52.当然.在某些16位编辑器下, int可能是2字节,那么结果是 int2 + DATE10 + double8 = 2010、队列和栈有什么区别 队列先进先出,栈后进先出11、写出以下代码的输出内容以下是引用片段: #include int inc(int a) return(+a); int multi(in
14、t*a,int*b,int*c) return(*c=*a*b); typedef int(FUNC1)(int in); typedef int(FUNC2) (int*,int*,int*); void show(FUNC2 fun,int arg1, int*arg2) INCp=&inc; int temp =p(arg1); fun(&temp,&arg1, arg2); printf(%dn,*arg2); main() int a; show(multi,10,&a); return 0; 答:11012、请找出下面代码中的所有错误说明:以下代码是把一个字符串倒序,如“abcd倒
15、序后变为“dcba以下是引用片段: 1、#includestring.h 2、main() 3、 4、 char*src=hello,world; 5、 char* dest=NULL; 6、 int len=strlen(src); 7、 dest=(char*)malloc(len); 8、 char* d=dest; 9、 char* s=srclen; 10、 while(len-!=0) 11、 d+=s-; 12、 printf(%s,dest); 13、 return 0; 14、答:方法1:以下是引用片段: int main() char* src = hello,world;
16、 int len = strlen(src); char* dest = (char*)malloc(len+1);/要为0分配一个空间 char* d = dest; char* s = &srclen-1;/指向最后一个字符 while( len- != 0 ) *d+=*s-; *d = 0;/尾部要加0 printf(%sn,dest); free(dest);/ 使用完,应当释放空间,以免造成内存汇泄露 return 0; 方法2:以下是引用片段: #include #include main() char str=hello,world; int len=strlen(str);
17、char t; for(int i=0; i t=stri; stri=strlen-i-1; strlen-i-1=t; printf(%s,str); return 0; 1.-1,2,7,28,126请问28和126中间那个数是什么 为什么 第一题的答案应该是43-1=63规律是n3-1(当n为偶数0,2,4)n3+1(当n为奇数1,3,5)答案:632.用两个栈实现一个队列的功能 要求给出算法和思路!设2个栈为A,B, 一开场均为空.入队:将新元素push入栈A;出队:(1)判断栈B是否为空;(2)如果不为空,那么将栈A中所有元素依次pop出并push到栈B;(3)将栈B的栈顶元素po
18、p出;这样实现的队列入队和出队的平摊复杂度都还是O(1), 比上面的几种方法要好。3.在c语言库函数中将一个字符转换成整型的函数是atool()吗,这个函数的原型是什么 函数名: atol功 能: 把字符串转换成长整型数用 法: long atol(const char *nptr);程序例:以下是引用片段: #include #include int main(void) long l; char *str = 98765432; l = atol(lstr); printf(string = %s integer = %ldn, str, l); return(0); 13.对于一个频繁使
19、用的短小函数,在C语言中应用什么实现,在C+中应用什么实现 c用宏定义,c+用inline14.直接链接两个信令点的一组链路称作什么 PPP点到点连接15.接入网用的是什么接口 16.voip都用了那些协议 17.软件测试都有那些种类 黑盒:针对系统功能的测试白合:测试函数功能,各函数接口18.确定模块的功能和模块的接口是在软件设计的那个队段完成的 概要设计阶段19.enum stringx1,x2,x3=10,x4,x5,x;问x= 0x801005,0x8010f4 ;20.unsigned char *p1;unsigned long *p2;p1=(unsigned char *)0x
20、801000;p2=(unsigned long *)0x810000;请问p1+5= ;p2+5= ;选择题:21.Ethternet链接到Internet用到以下那个协议 22.属于网络层协议的是:23.Windows消息调度机制是:A.指令队列;B.指令堆栈;C.消息队列;D.消息堆栈;24.unsigned short hash(unsigned short key)return (key)%256请问hash(16),hash(256)的值分别是:找错题:25.请问下面程序有什么错误 int a602501000,i,j,k;for(k=0;k=1000;k+)for(j=0;j25
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 著名企业 cc 数据结构 算法 试笔 试题
限制150内