对于百度第一次面试的相关题目进行整理如下:
一道智力题:10个瓶子,每个瓶子装100颗药,每颗药重量为10g,其中有N个瓶子被污染了(1<=N<=10),污染瓶子的每颗药变为11g,给一杆秤,如何秤一次就可以找出被污染的所有瓶子?
思路:加法分解思路入手,第一个瓶子取1个,第二个瓶子取2个,第三个瓶子取4(1+2+1)个,第四个瓶子取8个(1+2+4+1),以此类推,第i个瓶子取前面数字之和+1个药丸进行称量。将结果减去假设没有坏的情况的质量,对得到的差进行和的分解,即可找出对应得瓶子。二进制思路。。。
进程和线程区别,进程通信的方式?
把进程作为分配资源的基本单位,而把线程作为独立运行和独立调度的基本单位。
子进程和父进程有不同的代码和数据空间,而多个线程则共享数据空间,每个线程有自己的执行堆栈和程序计数器为其执行上下文。
进程间通信方式:(1)消息传递(管道,FIFO,posix,消息队列)。(2)同步(互斥锁,条件变量,读写锁)。(3)共享内存区(4)过程调用(RPC)。
共享内存+管道+信号灯+socket(消息队列)
线程停止,进程就会停止。多进程比多线程健壮。
进程开销大于线程。进程间不能共享变量,只能通过进程间通信实现,比如管道、文件、套接字等。
线程开销小,可以通过信号量实现多线程的互斥,在栈区启动,包括栈相关的指针,变量,共享进程数据。对于有序数组A和有序数组B,如何查找出A数组的元素在B数组的下标?(二分查找,如何优化。。。)
//start:查找的开始下标,num:查询的数字,返回下标 int binarySearch(int A[],int start,int num){ //查到就返回下标,否则返回-1 //异常判断 返回-1 int low=start; int high=A.length-1; while(low<=high){ int mid=(low+high)/2; if(A[mid]==num){ return mid; } if(A[mid]>num){ high=mid; }else{ low=mid; } } return -1; } 遍历B并进行查找 int start=0; int tmp[]=new int[B.length]; for(int i=0;i<B.length;i++){ int index=binarySearch(A,int start,B[i]); tmp[i]=index; if(index!=-1){ start=index+1;//缩小二分查找的范围 } }
在数组中查找3个数的和为S的数?threeSum fourSum问题。(难!)
threesum在twosum的算法上外部嵌套一层循环即可。
获取树的深度(队列容器,层次遍历)
- 字符串压缩解压缩算法(encode、decode)aaabbbacc->a3b3a1c2
- 海量数据处理(hash-〉hashmap-〉堆、topk问题-〉归并),给出思路即可。
- shell相关指令,find、wc统计
软链接、硬连接区别?
软链接:快捷方式
硬连接:指向相同inode的文件,删除原始文件,不影响。zookeeper原理?
ZooKeeper是一个分布式的,开放源码的分布式应用程序协调服务,它包含一个简单的原语集,分布式应用程序可以基于它实现同步服务,配置维护和命名服务等
参考TCP vs UDP
TCP:可靠、有序、重量级
UDP:不可靠、无序、轻量级
对实时性要求比较高的用UDP,对质量要求比较高的用TCP。
为何使用三次握手:解决网络中延迟的重复分组。防止server端一直等待,浪费资源。
为何需要四次挥手:tcp是全双工通信,接受到FIN时意味着没有数据再发来,但是还是可以继续发送数据。