微软等IT名企经典笔试100题(答案另外上传)

合集下载

笔试题及答案微软

笔试题及答案微软

笔试题及答案微软1. 问题:请解释什么是递归,并给出一个递归函数的例子。

答案:递归是一种编程技术,它允许一个函数调用自身来解决问题。

递归函数通常有两个主要部分:基本情况和递归情况。

基本情况是递归结束的条件,而递归情况是函数调用自身的地方。

示例代码:```pythondef factorial(n):if n == 0: # 基本情况return 1else: # 递归情况return n * factorial(n - 1)```2. 问题:在C#中,如何实现单例模式?答案:单例模式确保一个类只有一个实例,并提供一个全局访问点。

在C#中,可以通过私有构造函数和静态实例来实现。

示例代码:```csharppublic class Singleton{private static Singleton instance;private Singleton() { } // 私有构造函数public static Singleton GetInstance(){if (instance == null){instance = new Singleton();}return instance;}}```3. 问题:解释什么是闭包,并给出一个JavaScript中的闭包示例。

答案:闭包是一个函数和其周围的状态(词法环境)的组合。

闭包允许函数访问定义在其外部作用域的变量。

示例代码:```javascriptfunction createCounter() {let count = 0;return function() {count += 1;return count;};}const counter = createCounter();console.log(counter()); // 输出:1console.log(counter()); // 输出:2```4. 问题:在Java中,如何实现观察者模式?答案:观察者模式是一种设计模式,允许对象在状态变化时通知其他依赖对象。

微软招聘考题(附答案)

微软招聘考题(附答案)

第一组1.烧一根不均匀的绳,从头烧到尾总共需要1个小时。

现在有若干条材质相同的绳子,问如何用烧绳的方法来计时一个小时十五分钟呢?2.你有一桶果冻,其中有黄色、绿色、红色三种,闭上眼睛抓取同种颜色的两个。

抓取多少个就可以确定你肯定有两个同一颜色的果冻?3.如果你有无穷多的水,一个3公升的提捅,一个5公升的提捅,两只提捅形状上下都不均匀,问你如何才能准确称出4公升的水?4.一个岔路口分别通向诚实国和说谎国。

来了两个人,已知一个是诚实国的,另一个是说谎国的。

诚实国永远说实话,说谎国永远说谎话。

现在你要去说谎国,但不知道应该走哪条路,需要问这两个人。

请问应该怎么问?5.12个球一个天平,现知道只有一个和其它的重量不同,问怎样称才能用三次就找到那个球。

13个呢?(注意此题并未说明那个球的重量是轻是重,所以需要仔细考虑)6.在9个点上画10条直线,要求每条直线上至少有三个点?7.在一天的24小时之中,时钟的时针、分针和秒针完全重合在一起的时候有几次?都分别是什么时间?你怎样算出来的?8.怎么样种植4棵树木,使其中任意两棵树的距离相等?第二组1.为什么下水道的盖子是圆的?2.中国有多少辆汽车?3.将汽车钥匙插入车门,向哪个方向旋转就可以打开车锁?4.如果你要去掉中国的34个省(含自治区、直辖市和港澳特区及台湾省)中的任何一个,你会去掉哪一个,为什么?5.多少个加油站才能满足中国的所有汽车?6.想象你站在镜子前,请问,为什么镜子中的影象可以颠倒左右,却不能颠倒上下?7.为什么在任何旅馆里,你打开热水,热水都会瞬间倾泻而出?8.你怎样将Excel的用法解释给你的奶奶听?9.你怎样重新改进和设计一个ATM银行自动取款机?10.如果你不得不重新学习一种新的计算机语言,你打算怎样着手来开始?11.如果你的生涯规划中打算在5年内受到奖励,那获取该项奖励的动机是什么?观众是谁?12.如果微软告诉你,我们打算投资五百万美元来启动你的投资计划,你将开始什么样商业计划?为什么?13.如果你能够将全世界的电脑厂商集合在一个办公室里,然后告诉他们将被强迫做一件事,那件事将是什么?第三组1.你让工人为你工作7天,回报是一根金条,这个金条平分成相连的7段,你必须在每天结束的时候给他们一段金条。

微软笔试题目附答案

微软笔试题目附答案

微软笔试题目附答案微软笔试题目(附答案) 1.烧一根不均匀的绳子,从头烧到尾总共需要 1 个小时,问如何用烧绳子的方法来确定半小时的时间呢?2.10 个海盗抢到了100 颗宝石,每一颗都一样大小且价值连城。

他们决定这么分:(1)抽签决定自己的号码(1~10);(2)首先,由1 号提出分配方案,然后大家表决,当且仅当超过半数的人同意时,按照他的方案进行分配,否则将被扔进大海喂鲨鱼;(3)如果1 号死后,再由2 号提出分配方案,然后剩下的4 个人进行表决,当且仅当超过半数的人同意时,按照他的方案进行分配,否则将被扔入大海喂鲨鱼;(4)依此类推??条件:每个海盗都是很聪明的人,都能很理智地做出判断,从而做出选择。

问题:第一个海盗提出怎样的分配方案才能使自己的收益最大化?3.为什么下水道的盖子是圆的?4.中国有多少辆汽车?5.你让工人为你工作7 天,回报是一根金条,这根金条平分成相连的7 段,你必须在每天结束的时候给他们一段金条。

如果只允许你两次把金条弄断,你如何给你的工人付费?6.有一辆火车以每小时15 公里的速度离开北京直奔广州,同时另一辆火车以每小时20 公里的速度从广州开往北京。

如果有一只鸟,以30 公里每小时的速度和两辆火车同时启动,从北京出发,碰到另一辆车后就向相反的方向返回去飞,就这样依次在两辆火车之间来回地飞,直到两辆火车相遇。

请问,这只鸟共飞行了多长的距离?7.你有两个罐子以及50 个红色弹球和50 个蓝色弹球,随机选出一个罐子,随机选出一个弹球放入罐子,怎样给出红色弹球最大的选中机会?在你的计划里,得到红球的几率是多少?8.想像你站在镜子前,请问,为什么镜子中的影像可以左右颠倒,却不能上下颠倒呢?9.如果你有无穷多的水,一个3 公升的提捅,一个5 公升的提捅,两只提捅形状上下都不均匀,问你如何才能准确称出4 公升的水?10.你有一桶果冻,其中有黄色、绿色、红色三种,闭上眼睛抓取同种颜色的两个。

微软笔试题

微软笔试题
小明与弟弟过去,小明回来,用4s;
小明与爸爸过去,用6s;
总共用29s。
题目的关键是让速度差不多的一起走,免得过于拖累较快的一个人。
微软笔试题:编一个程序求质数的和
编一个程序求质数的和,例如F(7) = 2+3+5+7+11+13+17=58。
方法1:
对于从2开始的递增整数n进行如下操作:
方法2:
考虑除法复杂度有些高,可以使用移位操作代替除法。
将 x 和 1 进行按位与操作(x&1),如果结果为1,说明最后一位是1,统计值加1。
将x 向右一位(x >> 1),重复上面过程,直到移位后结果为0。
方法3:
如果需要统计很多数字,并且内存足够大,可以考虑将每个数对应的bit为1的数量记录下来,这样每次计算只是一次查找操作。
第三次:称7+18=x+2,得出x是23,23+9+18=50克盐.
剩下就是90克了.
第二种方法:
1.先把140克盐分为两份,每份70克
2.在把70克分为两份,每份35克
3.然后把两个砝码放在天平两边,把35克面粉分成两份也放在两边(15+7=20+2)
如果是苹果,则此篮中只有苹果;标有苹果的水果篮中只有橘子;标有橘子的水果篮中既有苹果也有橘子。
微软笔试题:不利用浮点运算,画一个圆
不利用浮点运算,在屏幕上画一个圆 (x**2 + y**2 = r**2,其中 r 为正整数)。
考虑到圆的对称性,我们只需考虑第一象限即可。
微软笔试题:判断数组中是否包含重复数字
给定一个长度为N的数组,其中每个元素的取值范围都是1到N。判断数组中是否有重复的数字。(原数组不必保留)

微软笔试题目1

微软笔试题目1

微软笔试真题一:微软笔试1.简要谈一下您对微软.NET 构架下remoting和webservice两项技术的理解以及实际中的应用。

答:WS主要是可利用HTTP,穿透防火墙。

而Remoting可以利用TCP/IP,二进制传送提高效率。

微软笔试2.公司要求开发一个继承System.Windows.Forms.ListView类的组件,要求达到以下的特殊功能:点击ListView各列列头时,能按照点击列的每行值进行重排视图中的所有行(排序的方式如DataGrid相似)。

根据您的知识,请简要谈一下您的思路答:根据点击的列头,包该列的ID取出,按照该ID排序后,在给绑定到ListView中。

微软笔试3.写出一条Sql语句:取出表A中第31到第40记录(SQLServer,以自动增长的ID作为主键,注意:ID可能不是连续的。

答:解1: select top 10 * from A where id not in (select top 30 idfrom A)解2: select top 10 * from A where id >(select max(id) from (selecttop 30 id from A )as A)微软笔试4.面向对象的语言具有________性、_________性、________性答:封装、继承、多态。

微软笔试5.能用foreach遍历访问的对象需要实现________________接口或声明________________方法的类型。

答:IEnumerable 、GetEnumerator。

微软笔试6.GC是什么? 为什么要有GC?答:GC是垃圾收集器。

程序员不用担心内存管理,因为垃圾收集器会自动进行管理。

要请求垃圾收集,可以调用下面的方法之一:System.gc()Runtime.getRuntime().gc()微软笔试7.String s = new String("xyz");创建了几个String Object?答:两个对象,一个是“xyx”,一个是指向“xyx”的引用对象s。

电子软件开发岗位招聘笔试题及解答(某世界500强集团)2024年

电子软件开发岗位招聘笔试题及解答(某世界500强集团)2024年

2024年招聘电子软件开发岗位笔试题及解答(某世界500强集团)(答案在后面)一、单项选择题(本大题有10小题,每小题2分,共20分)1、以下哪个选项不属于电子软件开发常用的编程语言?A、C语言B、JavaC、HTMLD、Python2、电子软件开发中,以下哪个阶段不属于软件生命周期?A、需求分析B、设计C、编码D、测试与部署3、在C++编程语言中,当一个类被声明为final时,这意味着:A)该类不能拥有任何成员函数B)该类不能派生出子类C)该类的所有成员变量必须是constD)该类只能有一个实例4、关于软件开发生命周期(SDLC),下列哪个阶段通常涉及识别项目需求并定义项目的范围?A)设计阶段B)实现阶段C)测试阶段D)需求分析阶段5、以下关于嵌入式系统开发,描述错误的是:A. 嵌入式系统通常是指用于特定用途的计算机系统B. 嵌入式系统通常使用专用的微控制器或处理器C. 嵌入式系统具有实时性要求,通常需要快速响应D. 嵌入式系统的软件通常是在通用操作系统上开发6、在电子软件开发中,以下哪种编程语言最适合用于开发实时操作系统(RTOS)?A. JavaB. CC. PythonD. Assembly7、以下哪个选项是描述电子软件开发中面向对象编程(OOP)核心概念的正确说法?A. 封装意味着将数据和方法分开存储B. 继承是指将一个类的方法和属性复制到另一个类C. 多态是指使用不同的类对象执行相同的方法D. 抽象是指通过定义接口来隐藏实现的细节8、以下哪种编程范式与电子软件开发中的事件驱动模型最为相关?A. 函数式编程B. 命令式编程C. 面向对象编程D. 面向过程编程9、以下哪个技术不属于嵌入式系统常用的编程语言?A. CB. JavaC. AssemblyD. Python 10、在电子软件开发中,以下哪个术语指的是一种用于保护软件免受未经授权访问或修改的技术?A. 隐写术B. 加密C. 防水D. 程序压缩二、多项选择题(本大题有10小题,每小题4分,共40分)1、在软件开发过程中,以下哪些选项是敏捷开发方法论的特点?A. 强调过程和工具B. 遵循详细的计划C. 响应变化胜于遵循计划D. 可工作的软件重于详尽的文档E. 客户协作高于合同谈判2、下列关于版本控制系统Git的说法中,哪几项是正确的?A. Git是一种分布式版本控制工具。

2023年微软招聘笔试试题及答案

2023年微软招聘笔试试题及答案

2023年微软招聘笔试试题及答案第一题题目:请解释什么是云计算?答案:云计算是一种通过网络提供计算资源和服务的模式。

它允许用户通过互联网访问虚拟化的计算资源,如计算能力、存储空间和软件应用。

这些资源可以根据需要进行动态分配和管理,为用户提供灵活、可扩展和可靠的计算环境。

第二题题目:请简述微软Azure的主要产品和服务。

答案:微软Azure是一种云计算平台,它提供一系列的产品和服务,包括:1. 虚拟机:Azure提供可扩展的虚拟机实例,用户可以根据需要创建和管理虚拟机来运行各种应用程序和服务。

2. 存储:Azure提供持久性存储服务,包括Blob存储、文件存储和表格存储,可以用于存储和访问各种数据。

3. 数据库:Azure提供多种数据库服务,包括SQL数据库、Cosmos DB和Azure数据库服务,适用于不同类型的数据存储和管理需求。

4. 人工智能:Azure提供人工智能服务,如计算机视觉、语音识别和自然语言处理,使开发人员能够构建智能应用程序和系统。

5. 网络:Azure提供虚拟网络服务,包括虚拟网络、子网和网络安全组,用户可以在Azure中创建可扩展的网络架构。

6. 安全和合规性:Azure提供安全和合规性服务,包括身份验证、访问控制、数据加密和合规性认证,以帮助用户确保数据的安全性和合规性。

第三题题目:请解释什么是软件开发生命周期(SDLC)?答案:软件开发生命周期(SDLC)是指软件开发过程中的一系列阶段和活动。

这些阶段包括需求分析、系统设计、编码、测试、部署和维护。

SDLC旨在确保软件开发过程的组织性、可控性和可重复性,以确保交付高质量的软件产品。

第四题题目:请解释什么是敏捷开发(Agile Development)?答案:敏捷开发是一种软件开发方法论,强调在开发过程中的灵活性、协作和快速迭代。

敏捷开发通过将开发过程分解为多个短期迭代周期(一般为2到4周),每个周期中完成一部分功能,以满足客户需求。

名企笔试题及答案

名企笔试题及答案

名企笔试题及答案一、选择题1. 下列哪项不是数据库系统的特点?A. 数据共享B. 数据独立性C. 数据安全性D. 数据冗余答案:D2. 在面向对象编程中,封装的主要目的是什么?A. 隐藏内部实现细节B. 提高执行效率C. 增加代码量D. 减少内存使用答案:A3. 以下哪个算法属于排序算法?A. 快速排序B. 深度优先搜索C. 广度优先搜索D. 动态规划答案:A4. 在计算机网络中,TCP和UDP协议的区别是什么?A. TCP是面向连接的,UDP是无连接的B. TCP是无连接的,UDP是面向连接的C. TCP和UDP都是面向连接的D. TCP和UDP都是无连接的答案:A5. 以下哪个选项不是操作系统的三大特征?A. 并发B. 共享C. 虚拟D. 多态答案:D二、简答题1. 请简述软件开发生命周期(SDLC)的六个阶段。

答案:需求分析、系统设计、编码实现、测试、部署、维护。

2. 在项目管理中,什么是WBS(Work Breakdown Structure)?答案:WBS是将项目分解成更小的、易于管理的部分的过程,它是一种层次结构,显示了项目的所有任务和子任务。

3. 什么是堆栈溢出(Stack Overflow)?答案:堆栈溢出是指程序尝试向堆栈中写入超过其分配空间的数据,导致堆栈超出其内存限制,这通常会导致程序崩溃。

三、编程题1. 编写一个函数,实现两个字符串的拼接。

示例代码(Python):```pythondef concatenate_strings(str1, str2):return str1 + str2print(concatenate_strings("Hello, ", "World!"))```2. 给定一个整数数组,请找出其中的最大值。

示例代码(Java):```javapublic class Main {public static void main(String[] args) {int[] numbers = {3, 5, 7, 2, 9, 8};int max = findMax(numbers);System.out.println("The maximum value is: " + max); }public static int findMax(int[] array) {int max = array[0];for (int i = 1; i < array.length; i++) {if (array[i] > max) {max = array[i];}}return max;}}```四、案例分析题1. 描述一个你遇到的技术挑战,以及你是如何解决它的。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

1.把二元查找树转变成排序的双向链表题目:输入一棵二元查找树,将该二元查找树转换成一个排序的双向链表。

要求不能创建任何新的结点,只调整指针的指向。

10/ \6 14/ \ / \4 8 12 16转换成双向链表4=6=8=10=12=14=16。

首先我们定义的二元查找树节点的数据结构如下:struct BSTreeNode{int m_nValue; // value of nodeBSTreeNode *m_pLeft; // left child of nodeBSTreeNode *m_pRight; // right child of node};2.设计包含min函数的栈。

定义栈的数据结构,要求添加一个min函数,能够得到栈的最小元素。

要求函数min、push以及pop的时间复杂度都是O(1)。

3.求子数组的最大和题目:输入一个整形数组,数组里有正数也有负数。

数组中连续的一个或多个整数组成一个子数组,每个子数组都有一个和。

求所有子数组的和的最大值。

要求时间复杂度为O(n)。

例如输入的数组为1, -2, 3, 10, -4, 7, 2, -5,和最大的子数组为3, 10, -4, 7, 2,因此输出为该子数组的和18。

4.在二元树中找出和为某一值的所有路径题目:输入一个整数和一棵二元树。

从树的根结点开始往下访问一直到叶结点所经过的所有结点形成一条路径。

打印出和与输入整数相等的所有路径。

例如输入整数22和如下二元树10/ \5 12/ \4 7则打印出两条路径:10, 12和10, 5, 7。

二元树节点的数据结构定义为:struct BinaryTreeNode // a node in the binary tree{int m_nValue; // value of nodeBinaryTreeNode *m_pLeft; // left child of nodeBinaryTreeNode *m_pRight; // right child of node};5.查找最小的k个元素题目:输入n个整数,输出其中最小的k个。

例如输入1,2,3,4,5,6,7和8这8个数字,则最小的4个数字为1,2,3和4。

第6题腾讯面试题:给你10分钟时间,根据上排给出十个数,在其下排填出对应的十个数要求下排每个数都是先前上排那十个数在下排出现的次数。

上排的十个数如下:【0,1,2,3,4,5,6,7,8,9】举一个例子,数值: 0,1,2,3,4,5,6,7,8,9分配: 6,2,1,0,0,0,1,0,0,00在下排出现了6次,1在下排出现了2次,2在下排出现了1次,3在下排出现了0次....以此类推..第7题微软亚院之编程判断俩个链表是否相交给出俩个单向链表的头指针,比如h1,h2,判断这俩个链表是否相交。

为了简化问题,我们假设俩个链表均不带环。

问题扩展:1.如果链表可能有环列?2.如果需要求出俩个链表相交的第一个节点列?第8题此贴选一些比较怪的题,,由于其中题目本身与算法关系不大,仅考考思维。

特此并作一题。

1.有两个房间,一间房里有三盏灯,另一间房有控制着三盏灯的三个开关,这两个房间是分割开的,从一间里不能看到另一间的情况。

现在要求受训者分别进这两房间一次,然后判断出这三盏灯分别是由哪个开关控制的。

有什么办法呢?2.你让一些人为你工作了七天,你要用一根金条作为报酬。

金条被分成七小块,每天给出一块。

如果你只能将金条切割两次,你怎样分给这些工人?3.★用一种算法来颠倒一个链接表的顺序。

现在在不用递归式的情况下做一遍。

★用一种算法在一个循环的链接表里插入一个节点,但不得穿越链接表。

★用一种算法整理一个数组。

你为什么选择这种方法?★用一种算法使通用字符串相匹配。

★颠倒一个字符串。

优化速度。

优化空间。

★颠倒一个句子中的词的顺序,比如将“我叫克丽丝”转换为“克丽丝叫我”,实现速度最快,移动最少。

★找到一个子字符串。

优化速度。

优化空间。

★比较两个字符串,用O(n)时间和恒量空间。

★假设你有一个用1001个整数组成的数组,这些整数是任意排列的,但是你知道所有的整数都在1到1000(包括1000)之间。

此外,除一个数字出现两次外,其他所有数字只出现一次。

假设你只能对这个数组做一次处理,用一种算法找出重复的那个数字。

如果你在运算中使用了辅助的存储方式,那么你能找到不用这种方式的算法吗?★不用乘法或加法增加8倍。

现在用同样的方法增加7倍。

第9题判断整数序列是不是二元查找树的后序遍历结果题目:输入一个整数数组,判断该数组是不是某二元查找树的后序遍历的结果。

如果是返回true,否则返回false。

例如输入5、7、6、9、11、10、8,由于这一整数序列是如下树的后序遍历结果:8/ \6 10/ \ / \5 7 9 11因此返回true。

如果输入7、4、6、5,没有哪棵树的后序遍历的结果是这个序列,因此返回false。

第10题翻转句子中单词的顺序。

题目:输入一个英文句子,翻转句子中单词的顺序,但单词内字符的顺序不变。

句子中单词以空格符隔开。

为简单起见,标点符号和普通字母一样处理。

例如输入“I am a student.”,则输出“student. a am I”。

第11题求二叉树中节点的最大距离...如果我们把二叉树看成一个图,父子节点之间的连线看成是双向的,我们姑且定义"距离"为两节点之间边的个数。

写一个程序,求一棵二叉树中相距最远的两个节点之间的距离。

第12题题目:求1+2+…+n,要求不能使用乘除法、for、while、if、else、switch、case等关键字以及条件判断语句(A?B:C)。

第13题:题目:输入一个单向链表,输出该链表中倒数第k个结点。

链表的倒数第0个结点为链表的尾指针。

链表结点定义如下:struct ListNode{int m_nKey;ListNode* m_pNext;};第14题:题目:输入一个已经按升序排序过的数组和一个数字,在数组中查找两个数,使得它们的和正好是输入的那个数字。

要求时间复杂度是O(n)。

如果有多对数字的和等于输入的数字,输出任意一对即可。

例如输入数组1、2、4、7、11、15和数字15。

由于4+11=15,因此输出4和11。

第15题:题目:输入一颗二元查找树,将该树转换为它的镜像,即在转换后的二元查找树中,左子树的结点都大于右子树的结点。

用递归和循环两种方法完成树的镜像转换。

例如输入:8/ \6 10/\ /\5 7 9 11输出:8/ \10 6/\ /\11 9 7 5定义二元查找树的结点为:struct BSTreeNode // a node in the binary search tree (BST){int m_nValue; // value of nodeBSTreeNode *m_pLeft; // left child of nodeBSTreeNode *m_pRight; // right child of node};第16题:题目(微软):输入一颗二元树,从上往下按层打印树的每个结点,同一层中按照从左往右的顺序打印。

例如输入8/ \6 10/ \ / \5 7 9 11输出8 6 10 5 7 9 11。

第17题:题目:在一个字符串中找到第一个只出现一次的字符。

如输入abaccdeff,则输出b。

分析:这道题是2006年google的一道笔试题。

第18题:题目:n个数字(0,1,…,n-1)形成一个圆圈,从数字0开始,每次从这个圆圈中删除第m个数字(第一个为当前数字本身,第二个为当前数字的下一个数字)。

当一个数字删除后,从被删除数字的下一个继续删除第m个数字。

求出在这个圆圈中剩下的最后一个数字。

July:我想,这个题目,不少人已经见识过了。

第19题:题目:定义Fibonacci数列如下:/ 0 n=0f(n)= 1 n=1\ f(n-1)+f(n-2) n=2输入n,用最快的方法求该数列的第n项。

分析:在很多C语言教科书中讲到递归函数的时候,都会用Fibonacci作为例子。

因此很多程序员对这道题的递归解法非常熟悉,但....呵呵,你知道的。

第20题:题目:输入一个表示整数的字符串,把该字符串转换成整数并输出。

例如输入字符串"345",则输出整数345。

第21题2010年中兴面试题编程求解:输入两个整数n 和m,从数列1,2,3.......n 中随意取几个数,使其和等于m ,要求将其中所有的可能组合列出来.第22题:有4张红色的牌和4张蓝色的牌,主持人先拿任意两张,再分别在A、B、C三人额头上贴任意两张牌,A、B、C三人都可以看见其余两人额头上的牌,看完后让他们猜自己额头上是什么颜色的牌,A说不知道,B说不知道,C说不知道,然后A说知道了。

请教如何推理,A是怎么知道的。

如果用程序,又怎么实现呢?第23题:用最简单,最快速的方法计算出下面这个圆形是否和正方形相交。

"3D坐标系原点(0.0,0.0,0.0)圆形:半径r = 3.0圆心o = (*.*, 0.0, *.*)正方形:4个角坐标;1:(*.*, 0.0, *.*)2:(*.*, 0.0, *.*)3:(*.*, 0.0, *.*)4:(*.*, 0.0, *.*)第24题:链表操作,(1).单链表就地逆置,(2)合并链表第25题:写一个函数,它的原形是int continumax(char *outputstr,char *intputstr)功能:在字符串中找出连续最长的数字串,并把这个串的长度返回,并把这个最长数字串付给其中一个函数参数outputstr所指内存。

例如:"abcd12345ed125ss123456789"的首地址传给intputstr后,函数将返回9,outputstr所指的值为12345678926.左旋转字符串题目:定义字符串的左旋转操作:把字符串前面的若干个字符移动到字符串的尾部。

如把字符串abcdef左旋转2位得到字符串cdefab。

请实现字符串左旋转的函数。

要求时间对长度为n的字符串操作的复杂度为O(n),辅助内存为O(1)。

27.跳台阶问题题目:一个台阶总共有n级,如果一次可以跳1级,也可以跳2级。

求总共有多少总跳法,并分析算法的时间复杂度。

这道题最近经常出现,包括MicroStrategy等比较重视算法的公司都曾先后选用过个这道题作为面试题或者笔试题。

28.整数的二进制表示中1的个数题目:输入一个整数,求该整数的二进制表达中有多少个1。

例如输入10,由于其二进制表示为1010,有两个1,因此输出2。

这是一道很基本的考查位运算的面试题。

相关文档
最新文档