C语言面试题总汇.doc

  1. 1、本文档共15页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
HYPERLINK /superroboy/archive/2006/10/18/1339830.aspx ?C语言面试题总汇 4.??? static有什么用途?(请至少说明两种) 1.限制变量的作用域 2.设置变量的存储域 7.??? 引用与指针有什么区别? 1) 引用必须被初始化,指针不必。 2) 引用初始化以后不能被改变,指针可以改变所指的对象。 3) 不存在指向空值的引用,但是存在指向空值的指针。 8.??? 描述实时系统的基本特性 在特定时间内完成特定的任务,实时性与可靠性 9.??? 全局变量和局部变量在内存中是否有区别?如果有,是什么区别? 全局变量储存在静态数据区,局部变量在堆栈 10.?? 什么是平衡二叉树? 左右子树都是平衡二叉树 且左右子树的深度差值的绝对值不大于1 11.?? 堆栈溢出一般是由什么原因导致的? 没有回收垃圾资源 12.?? 什么函数不能声明为虚函数? constructor 13.?? 冒泡排序算法的时间复杂度是什么? O(n^2) 14.?? 写出float x 与“零值”比较的if语句。 if(x0.000001x-0.000001) 16.?? Internet采用哪种网络协议?该协议的主要层次结构? tcp/ip 应用层/传输层/网络层/数据链路层/物理层 17.?? Internet物理地址和IP地址转换采用什么协议? ARP (Address Resolution Protocol)(地址解析協議) 18.IP地址的编码分为哪俩部分? IP地址由两部分组成,网络号和主机号。不过是要和“子网掩码”按位与上之后才能区分哪些是网络位哪些是主机位。 2.用户输入M,N值,从1至N开始顺序循环数数,每数到M输出该数值,直至全部输出。写出C程序。 循环链表,用取余操作做 3.不能做switch()的参数类型是: switch的参数不能为实型。 今天早上的面试题9道,比较难,向牛人请教,国内的一牛公司,坐落在北京北四环某大厦: 1、线形表a、b为两个有序升序的线形表,编写一程序,使两个有序线形表合并成一个有序升序线形表h; 答案在 请化大学 严锐敏《数据结构第二版》第二章例题,数据结构当中,这个叫做:两路归并排序 Linklist *unio(Linklist *p,Linklist *q){ linklist *R,*pa,*qa,*ra; pa=p; qa=q; R=ra=p; while(pa-next!=NULLqa-next!=NULL){ if(pa-dataqa-data){ ra-next=qa; qa=qa-next; } else{ ra-next=pa; pa=pa-next; } } if(pa-next!=NULL) ra-next=pa; if(qa-next!=NULL) ra-next==qa; return R; } 2、运用四色定理,为N个局域举行配色,颜色为1、2、3、4四种,另有数组adj[][N],如adj[i][j]=1则表示i区域与j区域相邻,数组color[N],如color[i]=1,表示i区域的颜色为1号颜色。 四色填充 3、用递归算法判断数组a[N]是否为一个递增数组。 递归的方法,记录当前最大的,并且判断当前的是否比这个还大,大则继续,否则返回false结束: bool fun( int a[], int n ) { if( n= =1 ) return true; if( n= =2 ) return a[n-1] = a[n-2]; return fun( a,n-1) ( a[n-1] = a[n-2] ); } 4、编写算法,从10亿个浮点数当中,选出其中最大的10000个。 用外部排序,在《数据结构》书上有 《计算方法导论》在找到第n大的数的算法上加工 5、编写一unix程序,防止僵尸进程的出现. 同学的4道面试题,应聘的职位是搜索引擎工程师,后两道超级难,(希望大家多给一些算发) 1.给两个数组和他们的大小,还有一动态开辟的内存,求交集,把交集放到动态内存dongtai,并且返回交集个数 long jiaoji(long* a[],long b[],long* alength,long blength,long* dongtai[]) 2.单连表的建立,把a--z26个字母插入到连表中,并且倒叙,还要打印! 方法1: typedef struct val {?? int date_1; ??? struct val *next; }*p; void main(void) {?? char c; ???? ??? for(c=122;c=97;c--) ?????? { p.date=c; ???????? p

文档评论(0)

zhuliyan1314 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档