• 面试题集锦---BY算法导论小组


    3.7题



    3.21题

    1.给定能随机生成整数 到 的函数,写出能随机生成整数 到 的函数。

    提示:两个random就可以有25种可能,每种可能都是等概率的


    2.判断一个自然数是否是某个数的平方,不能使用开方运算。

    提示:(1)使用二分查找法,对1到N之间的数字进行判断。复杂度为O(log n)

        (2)由于(n+1)^2 =n^2 + 2n + 1= ...= 1 + (2*1 + 1) + (2*2 + 1) + ... + (2*n + 1)
    注意到这些项构成了等差数列(每项之间相差2)。
    所以我们可以比较 N-1, N - 1 - 3, N - 1 - 3 - 5 ... 和0的关系。
    如果大于0,则继续减;如果等于0,则成功退出;如果小于 0,则失败退出。
    复杂度为O(n^0.5)。


    3.如何在半径为1的圆中随机选取一点。

    提示:用极坐标来表示


    4.皇冠用户仓库开销:有一个淘宝商户,在某城市有n个仓库,每个仓库的储货量不同,现在要通过货物运输,

    将每次仓库的储货量变成一致的,n个仓库之间的运输线路围城一个圈,即1->2->3->4->...->n->1->...,

    货物只能通过连接的仓库运输,设计最小的运送成本(运货量*路程)达到淘宝商户的要求,并写出代码。

      


    提示:遍历一遍,纪录欠的货量和多的货量,一旦有多的就向顺时针方向移动;复杂度:O(n)


    4.5题

    1.在黑板上写下50个数字:150.在接下来的49轮操作中,每次做如下动作:选取两个黑板上的数字ab

    擦去,在黑板上写|b - a|。请问最后一次动作之后剩下数字可能是什么?为什么?

    提示:找规律,要么留下全为奇数,要么为偶数

    2.如何判断链表无环?

    提示:(1)加一个数据结构,来记录链表的位置或者Key信息,遍历看看是不是会遇到相同的节点

    (2)用两个指针一起走,一个步长是1,一个步长是2,然后遍历看看是不是会重合


    3.1000桶酒,其中1桶有毒。而一旦吃了,毒性会在1周后发作。现在我们用小老鼠做实验,

    要在1周内找出那桶毒酒,问最少需要多少老鼠。

    提示:可以将酒混合后喝

    答案:10只。将酒编号为1~1000 将老鼠分别编号为1 2 4 8 16 32 64 128 256 512 喂酒时 让酒的编号等于老鼠编号的加和如:17号酒喂给1号和16号老鼠  76号酒喂给4号、8号和64号老鼠 七天后将死掉的老鼠编号加起来 得到的编号就是有毒的那桶酒 因为2的10次方等于1024 所以10只老鼠最多可以测1024桶酒

    证明如下:使用二进制表示:01, 10, 100, 1000, … , 1,000,000,000。对于任何一个小于1024的数,均可以采用前面的唯一一组二进制数来表示。故成立。



    4.输入一个整形数组,数组里有正数也有负数。数组中连续的一个或多个整数组成一个子数组,

    每个子数组都有一个和。求所有子数组的和的最大值。要求时间复杂度为O(n)。 
    例如输入的数组为1, -2, 3, 10, -4, 7, 2, -5,和最大的子数组为3, 10, -4, 7, 2因此输出为该子数组的和18
    提示:遍历一遍,遇到sum<0,就重新从正数开始计数

    5.输入n个整数,输出其中最小的k个。

    提示:(1)先将所有数字建小堆,然后弹出K个值就可以了;复杂度:n+k*lgn

    (2)现将任意k个数字建大堆,然后将剩下的数分别和堆顶数字比较,如果比堆顶数字小,就将堆顶的数字换掉,

    比较剩下的n-k个数字后,堆里剩下的数字就是最小的k个;复杂度:k+(n-k)*lgk


    6.设计包含min函数的栈

    提示:在栈的旁边在加一个数组,记录最小的数的位置






  • 相关阅读:
    gradle项目与maven项目互转
    GET和POST两种基本请求方法的区别
    gradle项目打war和jar包
    maven项目打war和jar
    winsw打包jar
    前端
    CentOS
    Vue
    Spring
    Vue
  • 原文地址:https://www.cnblogs.com/gremount/p/5768014.html
Copyright © 2020-2023  润新知