ImageVerifierCode 换一换
格式:DOCX , 页数:85 ,大小:69.50KB ,
资源ID:8063643      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/8063643.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(计算机应届毕业生常见面试题目.docx)为本站会员(b****6)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

计算机应届毕业生常见面试题目.docx

1、计算机应届毕业生常见面试题目1. 把二元查找树转换成排序的双向链表题目:输入一棵二元查找树,将该二元查找树转换成一个排序的双向链表。要求不能创建任何新的结点,只调整指针的指向。比如将二元查找树 10 / 6 14 / / 4 8 12 16转换成双向链表4=6=8=10=12=14=16。 分析:本题是微软的面试题。很多与树相关的题目都是用递归的思路来解决,本题也不例外。二元查找树BST的一个重要特性便是如果按照中序方式对其进行遍历,结果是一个有序的序列。 所以我们可以中序遍历整棵树。按照这个方式遍历树,比较小的结点总是最先被访问。如果我们每访问一个结点,假设之前访问过的结点已经调整成一个排序

2、好的双向链表,我们再调整当前结点的指针,将其链接到链表的末尾。当所有结点都访问过之后,整棵树也就转换成一个排序双向链表了。源码:#include using namespace std;typedef struct node int data; struct node *left; struct node *right;BSTNode;int InsertBST(BSTNode *&bt, int k) /作为叶子结点插入BST树 if(bt=NULL) bt=(BSTNode*)malloc(sizeof(BSTNode); bt-data=k; bt-left=bt-right=NULL;

3、 return 1; if(bt-data=k) return 0; if(bt-datak) return InsertBST(bt-left, k); if(bt-dataright, k);void CreateBST(BSTNode *&bt, int r, int n) int i; for(i=0; ileft, visited); cur-left=visited; if(visited!=NULL) visited-right=cur; visited=cur; ConvertToDLinkList(cur-right, visited); void DispDLinkList

4、(BSTNode *bt) while(bt!=NULL) printf(%d , bt-data); bt=bt-right; int main() int r5=3,88,9,42,16; BSTNode *bt=NULL; CreateBST(bt, r, 5); BSTNode *h=NULL; ConvertToDLinkList(bt, h); /查找双链表的开始结点 while(h-left!=NULL) h=h-left; /逐个打印显示结点值 DispDLinkList(h); system(pause); return 0;2. 设计包含min函数的栈 题目:定义栈的数据结

5、构,要求添加一个min函数,能够得到栈的最小元素。要求函数min、push以及pop的时间复杂度都是O(1)。 分析:这是去年google的一道面试题。我们需要一个辅助栈。每次push一个新元素的时候,同时将最小元素(或最小元素的位置。考虑到栈元素的类型可能是复杂的数据结构,用最小元素的位置将能减少空间消耗)push到辅助栈中;而每次pop一个元素出栈的时候,同时pop辅助栈。 源码:#include using namespace std;#define MaxSize 100typedef struct int dataMaxSize; int top;SqStack;/* * s作为主要

6、存放数据的栈,t作为辅助栈,存放当前栈中最小元素的下标 */void InitStack(SqStack *&s, SqStack *&t) s=(SqStack*)malloc(sizeof(SqStack); t=(SqStack*)malloc(sizeof(SqStack); s-top=t-top=-1; int Push(SqStack *s, SqStack *t, int data) if(s-top=MaxSize-1) return 0; s-top+; s-datas-top=data; if(t-top=-1) t-top+; t-datat-top=0; else t

7、-top+; if(datadatat-datat-top-1) t-datat-top=s-top; else t-datat-top=t-datat-top-1; return 1;int Pop(SqStack *s, SqStack *t, int &data) if(s-top=-1) return 0; data=s-datas-top; s-top-; t-top-; return 1; int min(SqStack *s, SqStack *t) assert(s-top!=-1&t-top!=-1); return s-datat-datat-top;int main()

8、SqStack *s, *t; InitStack(s,t); Push(s,t,12); Push(s,t,4); Push(s,t,-5); int m; printf(%dn, min(s,t); Pop(s,t,m); printf(%dn, min(s,t); Pop(s,t,m); printf(%dn, min(s,t); system(pause); return 0;3. 求子数组的最大和 题目:输入一个整形数组,数组里有正数也有负数。数组中连续的一个或多个整数组成一个子数组,每个子数组都有一个和。求所有子数组的和的最大值。要求时间复杂度为O(n)。例如输入的数组为1, -2

9、, 3, 10, -4, 7, 2, -5,和最大的子数组为3, 10, -4, 7, 2,因此输出为该子数组的和18。 分析:本题最初为2005年浙江大学计算机系的考研题的最后一道程序设计题,在2006年里包括google在内的很多知名公司都把本题当作面试题。由于本题在网络中广为流传,本题也顺利成为2006年程序员面试题中经典中的经典。 如果不考虑时间复杂度,我们可以枚举出所有子数组并求出他们的和。不过非常遗憾的是,由于长度为n的数组有O(n2)个子数组;而且求一个长度为n的数组的和的时间复杂度为O(n)。因此这种思路的时间是O(n3)。因为要求是O(N)的复杂度,因此需采用的DP的思想,记

10、录下当前元素之和(为其最优状态,既最大),将其与目前所得的最大和比较,若大于则更新,否则继续。状态的累加遵循这个过程:如果当前和小于0,则放弃该状态,将其归零。 很容易理解,当我们加上一个正数时,和会增加;当我们加上一个负数时,和会减少。如果当前得到的和是个负数,那么这个和在接下来的累加中应该抛弃并重新清零,不然的话这个负数将会减少接下来的和。基于这样的思路,我们可以写出如下代码。源码:#include using namespace std;#define MaxSize 100int FindGreatestSubSum(int r,int n,int &start,int &end) i

11、nt maxSum,curSum; maxSum=curSum=0; int curStart=0, curEnd=0; for (int i=0;in;i+) curSum+=ri; curEnd=i; if(curSummaxSum) maxSum=curSum; start=curStart; end=curEnd; if(maxSum=0) /若是数组中的元素均为负数,则输出里面的最大元素 maxSum=r0; /当然这步也可以写到上面一个循环里 int k; for(int i=1;in;i+) if(maxSumri) maxSum=ri; k=i; start=end=k; re

12、turn maxSum;int main() int a8=-51, -2, -3, 10, -4, -7, -2, -5; int start=0,end=0; coutFindGreatestSubSum(a,8,start,end)endl; coutstart end; system(pause); return 0;4. 在二元树中找出和为某一值的所有路径 题目:输入一个整数和一棵二元树。从树的根结点开始往下访问一直到叶结点所经过的所有结点形成一条路径。打印出和与输入整数相等的所有路径。例如输入整数22和如下二元树 10 / 5 12 / 4 7 则打印出两条路径:10, 12和10

13、, 5, 7。二元树结点的数据结构定义为:struct BinaryTreeNode / a node in the binary tree int m_nValue; / value of node BinaryTreeNode *m_pLeft; / left child of node BinaryTreeNode *m_pRight; / right child of node; 分析:这是XX的一道笔试题,考查对树这种基本数据结构以及递归函数的理解。当访问到某一结点时,把该结点添加到路径上,并累加当前结点的值。如果当前结点为叶结点并且当前路径的和刚好等于输入的整数,则当前的路径符合要

14、求,我们把它打印出来。如果当前结点不是叶结点,则继续访问它的子结点。当前结点访问结束后,递归函数将自动回到父结点。我们不难看出保存路径的数据结构实际上是一个栈结构,因为路径要与递归调用状态一致,而递归调用本质就是一个压栈和出栈的过程。 源码:#include using namespace std;#define MaxSize 100typedef struct node int data; struct node *left, *right;BSTNode;int InsertBST(BSTNode *&t, int d) if(t=NULL) t=(BSTNode*)malloc(siz

15、eof(BSTNode); t-data=d; t-left=t-right=NULL; return 1; if(t-data=d) return 0; if(t-datad) return InsertBST(t-left, d); if(t-dataright, d);void CreateBST(BSTNode *&t, int r, int n) int i; for(i=0; ileft=NULL&b-right=NULL) for(i=0; idata=expSum) printf(%d ,b-data); /主要是最后这个点没压栈,故单独打印 for(i=curp-1;i=0;

16、i-) printf(%d ,pathi); printf(n); else pathcurp=b-data; curp+; AllPath(b-left,path,curp, expSum); AllPath(b-right,path,curp, expSum); curp-; int main() int r7=6,3,4,7,1,9,10; BSTNode *t=NULL; CreateBST(t,r,7); int pathMaxSize; AllPath(t,path,0, 13); system(pause); return 0;5. 查找最小的k个元素 题目:输入n个整数,输出其

17、中最小的k个。例如输入1,2,3,4,5,6,7和8这8个数字,则最小的4个数字为1,2,3和4。 分析:这道题最简单的思路莫过于把输入的n个整数排序,这样排在最前面的k个数就是最小的k个数。只是这种思路的时间复杂度为O(nlogn)。我们试着寻找更快的解决思路。 我们可以先创建一个大小为k的数据容器来存储最小的k个数字。接下来我们每次从输入的n个整数中读入一个数。如果容器中已有的数字少于k个,则直接把这次读入的整数放入容器之中;如果容器中已有k个数字了,也就是容器已满,此时我们不能再插入新的数字而只能替换已有的数字。我们找出这已有的k个数中最大值,然后拿这次待插入的整数和这个最大值进行比较。

18、如果待插入的值比当前已有的最大值小,则用这个数替换替换当前已有的最大值;如果带插入的值比当前已有的最大值还要大,那么这个数不可能是最小的k个整数之一,因为我们容器内已经有k个数字比它小了,于是我们可以抛弃这个整数。 因此当容器满了之后,我们要做三件事情:一是在k个整数中找到最大数,二是有可能在这个容器中删除最大数,三是可能要插入一个新的数字,并保证k个整数依然是排序的。如果我们用一个二叉树来实现这个数据容器,那么我们能在O(logk)时间内实现这三步操作。因此对于n个输入数字而言,总的时间效率就是O(nlogk)。我们可以选择用不同的二叉树来实现这个数据容器。由于我们每次都需要找到k个整数中的

19、最大数字,我们很容易想到用最大堆。在最大堆中,根结点的值总是大于它的子树中任意结点的值。于是我们每次可以在O(1)得到已有的k个数字中的最大值,但需要O(logk)时间完成删除以及插入操作。源码:#include using namespace std;#define MaxSize 100#define K 3int heapK;void HeapAdjust(int r, int low, int high) int i=low, j=2*i+1, tmp; tmp=ri; while(j=high) if(jhigh&rjrj+1) j+; if(tmp=0; i-) HeapAdjus

20、t(r,i,n-1); void GetTopK(int r, int n) int i; for(i=0; iK; i+) heapi=ri; CreateHeap(heap,K); for(i=K; iri) heap0=ri; HeapAdjust(heap, 0, K-1); int main() int r12=3,7,-24,60,17,0,36,788,224,40,27,99; GetTopK(r,12); int i; for(i=0; iK; i+) printf(%d , heapi); system(pause); return 0;6. 判断整数序列是不是二元查找树的

21、后序遍历结果 题目:输入一个整数数组,判断该数组是不是某二元查找树的后序遍历的结果。如果是返回true,否则返回false。 例如输入5、7、6、9、11、10、8,由于这一整数序列是如下树的后序遍历结果: 8 / 6 10 / / 5 7 9 11因此返回true。如果输入7、4、6、5,没有哪棵树的后序遍历的结果是这个序列,因此返回false。 分析:这是一道trilogy的笔试题,主要考查对二元查找树的理解。在后续遍历得到的序列中,最后一个元素为树的根结点。从头开始扫描这个序 列,比根结点小的元素都应该位于序列的左半部分;从第一个大于跟结点开始到跟结点前面的一个元素为止,所有元素都应该大

22、于跟结点,因为这部分元素对应的是 树的右子树。根据这样的划分,把序列划分为左右两部分,我们递归地确认序列的左、右两部分是不是都是二元查找树。源码:#include using namespace std;int VerifyBST(int r, int n) int i,j,root,left,right; if(n=0) return 0; root=rn-1; left=right=1; for(i=0; iroot) break; for(j=i; jn-1; j+) if(rj0) left=VerifyBST(r,i); if(jn-1) right=VerifyBST(r+i,n-

23、i-1); return (left&right);int main() /*int arr1 = 5,7,6,9,11,10,8; int arr2 = 7,4,6,5; if(VerifyBST(arr1,7) printf(yesn); else printf(non);*/ system(pause); return 0;7. 翻转句子中单词的顺序 题目:输入一个英文句子,翻转句子中单词的顺序,但单词内字符的顺序不变。句子中单词以空格符隔开。为简单起见,标点符号和普通字母一样处理。例如输入“I am a student.”,则输出“student. a am I”。 分析:由于编写字符

24、串相关代码能够反映程序员的编程能力和编程习惯,与字符串相关的问题一直是程序员笔试、面试题的热门题目。本题也曾多次受到包括微软在内的大量公司的青睐。 由于本题需要翻转句子,我们先颠倒句子中的所有字符。这时,不但翻转了句子中单词的顺序,而且单词内字符也被翻转了。我们再颠倒每个单词内的字符。由于单词内的字符被翻转两次,因此顺序仍然和输入时的顺序保持一致。还是以上面的输入为例子。翻转“I am a student.”中所有字符得到“.tneduts a ma I”,再翻转每个单词中字符的顺序得到“students. a am I”,正是符合要求的输出。源码:#include using namespa

25、ce std;void reverse(char *begin, char *end) char tmp; if(begin=NULL|end=NULL) return; while(beginend) tmp=*begin; *begin=*end; *end=tmp; begin+; end-; /先逆转整个句子,然后从首字符开始扫描,/每扫描到一个单词(遇到空白或结束字符),对这个单词进行逆转。char *ReverseSentence(char *s) if(s=NULL) return NULL; char *begin, *end; begin=end=s; while(*end!

26、=0) end+; end-; reverse(begin,end); while(*begin!=0) end=begin; while(*end!= &*end!=0) end+; end-; reverse(begin,end); if(*(end+1)= ) begin=end+2; else begin=end+1; return s;int main() char a100 = I am a student.; ReverseSentence(a); coutaendl; system(pause); return 0;8. 求1+2+.+n 题目:求1+2+n,要求不能使用乘除法、for、while、if、else、switch、case等关键字以及条件判断语句(A?B:C)。 分析:这道题没有多少实际意义,因为在软件开发中不会有这么变态的限制。但这道题却能有效地考查发散思维能力,而发散思维能力能反映出对编程相关技术理解的深刻程度。通常求1+2+n除了用公式n(n+1)/2之外,无外乎循环和递归两种思路。由于已经明确限制for和while的使用,循环已经不能再用了。同样,递归函数也需要用if语句或者条件判断语句来判断是继续递

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1