滴滴一面(2018.4.25)

    总之把这些乱七八糟的面试都写在上边为秋招做积累吧。

    虽然一直想搞明白自己到底适合做算法还是做开发,但是问的问题都是基础....很奇怪,就当写个日记总结一下吧。

1.有一个长度为1m的绳子,随机切成三段,问有多大的可能性,三段绳子能凑成三角形?

    这是一个很经典的高中时期的线性规划的问题,首先三段绳子为 x,y,1-x-y。限定条件有

    a.x+y<1    b.0<x<1  c.0<y<1  d.x+y>1-x-y; x+(1-x-y)>y; y+(1-x-y)>x;

    最后解完就成了阴影部分,概率是  0.25


2. 一串数字,从0到n不重复,现在随机去除2个数字,并打乱放到一个n-1大小的空间中,如何快速找出这两个数字?

    典型的排序问题,有两种解法:

    a. 原有位置不懂,用一个快排或者归并排序,升序拍好,之后遍历拍好的数组,前一个与后一个做差,如果差是1则正常,如果差是2则说明这两个数中间有一个空缺,如果差为3这说明这两个去除的数都在这两个差为3的数中间。这种做法的时间复杂度为O(nlogn),空间复杂度倒是蛮小,为O(2)

    b.第二种方案是开辟一个O(n)大小的数组a[n]={0};之后遍历第一个数组,把里边包含的数跟a[n]对应,原数组中有哪个数,就把对应a[i]从0变成1,这样遍历一次后,a[n]中的值为0的下标进行返还即可。这种时间复杂度为O(n),空间复杂度也为O(n)。


3.怎么确定指针中是否有环?如果有环,环的入口在哪?

   经典的链表问题。

   a.怎么确定有环?

    设两个指针指向头结点,一个指针p=p->next,另外一个为pp=pp->next,如果两个指针顺次走到了尾结点nullptr则没有环,如果二者相撞,此时停止,说明有环。

    b.怎么确定环内的节点的数量?

    借助前一问中的两个指针,确定了有环,并在环中一个位置相交。之后定义一个新节点ppp=ppp->next遍历这个环,遍历一遍就回到了原始的ppp的位置,此时环的数量为n。

    c.怎么确定环的入口?

    在第二问的基础上,知道了环的数量,设立两个指针,p1和p2,用for循环让p1先往前走n步,之后p1和p2也同步向前走,直到p1和p2相撞,这个时候p2的位置就是环的入口。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值