【微软】2011年9月笔试题

这篇博客整理了微软2011年9月的笔试题目,涉及排序算法、编译过程、字符串操作、阶乘计算、二进制位运算、图的最短路径算法、二叉树异构、数列计算、Excel列名规则、前缀表达式、2的幂判断、抽象类特性、MVC设计模式及数组操作等知识点。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

根据明哥博客huiguixian的专栏整理:

1、N个数,范围从-N到N,可能重复,排序时间复杂度最好能到多少?

答案:计数排序和位图排序都可以达到O(n)的时间复杂度。


2、编译过程的哪个阶段完成后会产生parse tree

答案 :编译过程为扫描程序-->语法分析-->语义分析-->源代码优化-->代码生成器-->目标代码优化;

语法分析的结果为分析树parse tree或者语法树syntax tree


3、拷贝字符串当src和dest有overlap时,memcpy memmove哪个是安全的

答案:

   strcpy    extern char *strcpy(char *dest,char *src);  
   功能:把src所指由NULL结束的字符串复制到dest所指的数组中
   说明:src和dest所指内存区域不可以重叠且dest必须有足够的空间来容纳src的字符串。
   返回指向dest的指针
  
   memcpy   extern void *memcpy(void *dest,void *src,unsigned int count);
   功能:由src所指内存区域复制count个字符串到dest所指内存区域.
   说明:src和dest所指内存区域不能重叠,函数返回指向dest的指针.
      
   memmove    void *memmove (void *dest, const void *src, size_t n);
   从src所指向的对象复制n个字符到dest所指向的对象中。返回指针为dest的值。不会发生内存重叠。


4、99!的阶乘结果末尾0的个数?

答案:任何带0的数之所以能产生尾数0是因为它能拆出一个5来,但是25可以解析出两个5来,所以99的计算方法可以这样

       99/5 = 19, 19/5 = 3, 3/5 = 0,所以99末尾0的个数为22 


5、给定一个二进制串00

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值