`
EmmaZhao
  • 浏览: 32278 次
  • 性别: Icon_minigender_2
  • 来自: 北京
最近访客 更多访客>>
社区版块
存档分类
最新评论

【转】2011阿里云计算研发中心笔试题(45minutes)

 
阅读更多
2011阿里云计算研发中心笔试题(45minutes)

引用


应聘职位:软件开发工程师-数据平台

1.状态转换图,有限自动机,正则表达式

2.最小堆,删除堆根节点,画出任意结果

3.Heap与stack在进程中的区别

4.硬盘概率问题,对立事件,独立事件,平均分布,一季度,一年

5.工厂分布距离最小问题

6.多线程输出变量的所以可能值

7.补充题,堆排序补充

8.整数数组中求相加和最大的子数组,时间复杂度为O(n),编程语言不限(C/C /JAVA)

附加知识:

一个由C/C++编译的程序占用的内存分为以下几个部分

1、栈区(stack)— 由编译器自动分配释放 ,存放函数的参数值,局部变量的值等。其操作方式类似于数据结构中的栈。

2、堆区(heap) — 一般由程序员分配释放, 若程序员不释放,程序结束时可能由OS回收 。注意它与数据结构中的堆是两回事,分配方式倒是类似于链表。

3、全局区(静态区)(static)—,全局变量和静态变量的存储是放在一块的,初始化的全局变量和静态变量在一块区域, 未初始化的全局变量和未初始化的静态变量在相邻的另一块区域。 - 程序结束后有系统释放

4、文字常量区 —常量字符串就是放在这里的。 程序结束后由系统释放

5、程序代码区—存放函数体的二进制代码。

Heap:http://en.wikipedia.org/wiki/Heap_(data_structure)
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics