个人面试总结-百度复合搜索部

对于百度第一次面试的相关题目进行整理如下:

  1. 一道智力题:10个瓶子,每个瓶子装100颗药,每颗药重量为10g,其中有N个瓶子被污染了(1<=N<=10),污染瓶子的每颗药变为11g,给一杆秤,如何秤一次就可以找出被污染的所有瓶子?

    思路:加法分解思路入手,第一个瓶子取1个,第二个瓶子取2个,第三个瓶子取4(1+2+1)个,第四个瓶子取8个(1+2+4+1),以此类推,第i个瓶子取前面数字之和+1个药丸进行称量。将结果减去假设没有坏的情况的质量,对得到的差进行和的分解,即可找出对应得瓶子。二进制思路。。。

  2. 进程和线程区别,进程通信的方式?

    把进程作为分配资源的基本单位,而把线程作为独立运行和独立调度的基本单位。
    子进程和父进程有不同的代码和数据空间,而多个线程则共享数据空间,每个线程有自己的执行堆栈和程序计数器为其执行上下文。
    进程间通信方式:(1)消息传递(管道,FIFO,posix,消息队列)。(2)同步(互斥锁,条件变量,读写锁)。(3)共享内存区(4)过程调用(RPC)。
    共享内存+管道+信号灯+socket(消息队列)
    线程停止,进程就会停止。多进程比多线程健壮。
    进程开销大于线程。进程间不能共享变量,只能通过进程间通信实现,比如管道、文件、套接字等。
    线程开销小,可以通过信号量实现多线程的互斥,在栈区启动,包括栈相关的指针,变量,共享进程数据。

  3. 对于有序数组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;//缩小二分查找的范围
        }
    }
  4. 在数组中查找3个数的和为S的数?threeSum fourSum问题。(难!)

    threesum在twosum的算法上外部嵌套一层循环即可。

  5. 获取树的深度(队列容器,层次遍历)

  6. 字符串压缩解压缩算法(encode、decode)aaabbbacc->a3b3a1c2
  7. 海量数据处理(hash-〉hashmap-〉堆、topk问题-〉归并),给出思路即可。
  8. shell相关指令,find、wc统计
  9. 软链接、硬连接区别?

    软链接:快捷方式
    硬连接:指向相同inode的文件,删除原始文件,不影响。

  10. zookeeper原理?

    ZooKeeper是一个分布式的,开放源码的分布式应用程序协调服务,它包含一个简单的原语集,分布式应用程序可以基于它实现同步服务,配置维护和命名服务等
    参考

  11. TCP vs UDP

    TCP:可靠、有序、重量级
    UDP:不可靠、无序、轻量级
    对实时性要求比较高的用UDP,对质量要求比较高的用TCP。
    为何使用三次握手:解决网络中延迟的重复分组。防止server端一直等待,浪费资源。
    为何需要四次挥手:tcp是全双工通信,接受到FIN时意味着没有数据再发来,但是还是可以继续发送数据。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值