banner
李大仁博客

李大仁博客

天地虽大,但有一念向善,心存良知,虽凡夫俗子,皆可为圣贤。

分享几条来自微软(Microsoft)的算法设计笔试试题

今天晚间上网转了转,看到了,几条来自微软(Microsoft)的几条笔试试题,主要是针对微软学生中心的实习机会的,诸位如果想到微软实习的话,可以考虑自己做做看,感觉上对初学者比较困难,本人目前是没时间写代码了,最近忙者考试,诸位如果有想法的话,直接留言,或者可以跟我联系吧,

第一题 一个整数数列,元素取值可能是 0~65535 中的任意一个数,相同数值不会重复出现 。0 是例外,可以反复出现。 请设计一个算法,当你从该数列中随意选取 5 个数值,判断这 5 个数值是否连续相 邻。

注意: - 5 个数值允许是乱序的。比如: 8 7 5 0 6 - 0 可以通配任意数值。比如:8 7 5 0 6 中的 0 可以通配成 9 或者 4 - 0 可以多次出现。 - 复杂度如果是 O (n2) 则不得分。

试题 2 设计一个算法,找出二叉树上任意两个结点的最近共同父结点。 复杂度如果是 O (n2) 则不得分。

试题 3 一棵排序二叉树,令 f=(最大值 + 最小值)/2,设计一个算法,找出距离 f 值最近、

大于 f 值的结点。 复杂度如果是 O (n2) 则不得分。

试题 4 一个整数数列,元素取值可能是 1~N(N 是一个较大的正整数)中的任意一个数,

相同数值不会重复出现。设计一个算法,找出数列中符合条件的数对的个数,满

足数对中两数的和等于 N+1。 复杂度最好是 O (n),如果是 O (n2) 则不得分。

加载中...
此文章数据所有权由区块链加密技术和智能合约保障仅归创作者所有。