零零总总的面试题(2)

1.创新工场--由图的邻接表求【深度&广度】遍历

(http://blog.csdn.net/qitian0008/article/details/8044725)


上图更正下:最后一行的H的指向为D和G

深度优先遍历结果为:

A_>B->C->D->G->H->F->E

广度优先遍历:

ABCEDFGH

2.题目:输入一个已经按升序排序过的数组和一个数字sum,在数组中查找两个数,使得它们的和正好是输入的那个数字。

要求时间复杂度是O(n)。如果有多对数字的和等于输入的数字,输出任意一对即可。

例如输入数组1、2、4、7、11、15 和数字15。由于4+11=15,因此输出4 和11。

答案:(http://blog.csdn.net/qitian0008/article/details/7874872)

3.输入两个整数n 和m,从数列1,2,3.......n 中随意取几个数,使其和等于m ,要求将其中所有的可能组合列出来.

答案:(http://blog.csdn.net/qitian0008/article/details/7874915)

4.

一个整数数组,长度为n,将其分为m 份,使各份的和相等,求m的最大值

比如:

{3,2,4,3,6} 可以分成:

{3,2,4,3,6} m=1;

{3,6}{2,4,3}           m=2

{3,3}{2,4}{6}         m=3 所以m 的最大值为3

答案:(http://blog.csdn.net/qitian0008/article/details/7888907)

5.N对括号可以有多少种匹配排列方式?比如两对括号可以有两种:()()和(())

答案:(http://blog.csdn.net/qitian0008/article/details/7948262)

6.

调整数组顺序使奇数位于偶数前面。

题目:输入一个整数数组,调整数组中数字的顺序,使得所有奇数位于数组的前半部分,

所有偶数位于数组的后半部分。要求时间复杂度为O(n)。

答案:(http://blog.csdn.net/qitian0008/article/details/7948275)


你可能感兴趣的:(面试题,创新工场)