题目杂项汇总之智力题目
2011-09-25 22:33
357 查看
给出一行C语言表达式,判断给定的整数是否是一个2的幂。(谷歌面试智力题)
假定x:if((x&(x-1))==0)成立的话就是2的幂
一个大小为N的数组,所有数都是不超过N-1的正整数。用O(N)的时间找出重复的那个数(假设只有一个)。一个大小为N的数组,所有数都是不超过N+1的正整数。用O(N)的时间找出没有出现过的那个数(假设只有一个)。(谷歌面试智力题)
这题有几种解法,一种是求和做减法就可以得出具体的数,但是这个做法不一定是最好的方法,毕竟是会出现各种异常情况,比如:数据溢出等
还有一种做法就是做标记,如果你认为开辟uchar仍然占用内存很大,那么可以试试bit来做记录,自己写一个用bit做标记的类,或者干脆直接借助stl bitset来帮你实现。
假定x:if((x&(x-1))==0)成立的话就是2的幂
一个大小为N的数组,所有数都是不超过N-1的正整数。用O(N)的时间找出重复的那个数(假设只有一个)。一个大小为N的数组,所有数都是不超过N+1的正整数。用O(N)的时间找出没有出现过的那个数(假设只有一个)。(谷歌面试智力题)
这题有几种解法,一种是求和做减法就可以得出具体的数,但是这个做法不一定是最好的方法,毕竟是会出现各种异常情况,比如:数据溢出等
还有一种做法就是做标记,如果你认为开辟uchar仍然占用内存很大,那么可以试试bit来做记录,自己写一个用bit做标记的类,或者干脆直接借助stl bitset来帮你实现。
相关文章推荐
- 题目杂项汇总之智力题目
- 各种智力面试题目汇总
- 题目汇总
- 在线编程题目汇总一
- Web 前端面试题目及答案汇总
- C++面试常见题目问与答(汇总二)
- 【转帖】C/C++ 笔试、面试题目大汇总
- java 阿里面试常见30道题目汇总
- C/C++ 笔试、面试题目大汇总(三)
- 4月题目汇总2(4.23---4.29)
- Java笔试题目汇总122题
- [Offer收割]编程练习赛3 - 题目3 : 智力竞赛
- 语法面试等题目汇总
- linux驱动面试题目汇总
- C/C++ 笔试、面试题目大汇总
- C/C++笔试、面试题目大汇总
- HTML5面试题目汇总(一)
- C++题目汇总
- SAT历年真题之:作文题目汇总(三)
- 大型公司笔试题目汇总(2)——网易计算机类笔试题目