美文网首页Java架构技术进阶
疫情划水,宅家3个月吃透算法笔记后打开了“字节跳动新世界”

疫情划水,宅家3个月吃透算法笔记后打开了“字节跳动新世界”

作者: 代码搬运者Java | 来源:发表于2020-05-08 18:55 被阅读0次

    186道高阶算法题和高阶算法学习资料已经被我整理成PDF,有需要这份PDF的朋友关注后转发后点点我即可获取免费下载方式

    算法是敲门砖

    对于字节这样注重算法的大厂来说,不会算法基本上是与之无缘。前阵子因为疫情原因离职三个月,凭着一份算法宝典,在字节打开了新世界。

    宅家三个月吃透算法笔记,面试字节,面试官朝我比了个“ok”

    大厂必考:186道算法真题(带解析)

    1. 有1、2、3、4个数字,能组成多少个互不相同且无重复数字的三位数?都是多少?
    2. 一个整数,它加上100后是一个完全平方数,加上168又是一个完全平方数,请问该数是多少?
    3. 输入某年某月某日,判断这一天是这一年的第几天?
    4. 输入三个整数x,y,z,请把这三个数由小到大输出。
    5. 输出9*9口诀?
    6. 利用递归方法求5!
    7. 两个乒乓球队进行比赛,各出三人。甲队为a,b,c三人,乙队为x,y,z三人。已抽签决定比赛名单。有人向队员打听比赛的名单。a说他不和x比,c说他不和x,z比,请编程序找出三队赛手的名单。
    8. 有一分数序列:2/1,3/2,5/3,8/5,13/8,21/13...求出这个数列的前20项之和
    9. 兔子的规律为数列1,1,2,3,5,8,13,21....
    10. 判断101-200之间有多少个素数,并输出所有素数。
    11. 打印出所有的 "水仙花数 ",所谓 "水仙花数 "是指一个三位数,其各位数字立方和等于该数本身。例如:153是一个 "水仙花数 ",因为153=1的三次方+5的三次方+3的三次方
    12. 将一个正整数分解质因数。例如:输入90,打印出90=233*5
    13. 利用条件运算符的嵌套来完成此题:学习成绩> =90分的同学用A表示,60-89分之间的用B表示
    14. 输入两个正整数m和n,求其最大公约数和最小公倍数
    15. 输入一行字符,分别统计出其中英文字母、空格、数字和其它字符的个数
    16. 求s=a+aa+aaa+aaaa+aa...a的值,其中a是一个数字。例如2+22+222+2222+22222(此时共有5个数相加),几个数相加有键盘控制
    17. 一个数如果恰好等于它的因子之和,这个数就称为 "完数 "。例如6=1+2+3.编程 找出1000以内的所有完数
    18. 一球从100米高度自由落下,每次落地后反跳回原高度的一半;再落下,求它在 第10次落地时,共经过多少米?第10次反弹多高
    19. 给一个不多于5位的正整数,要求:一、求它是几位数,二、逆序打印出各位数字
    20. 请输入星期几的第一个字母来判断一下是星期几,如果第一个字母一样,则继续判断第二个字母。
    宅家三个月吃透算法笔记,面试字节,面试官朝我比了个“ok”

    刷题能理解算法题答案的由来,但是真正面试考的是你是否真正搞懂了算法,搞懂算法其实真不算难。多看资料多刷题,一切都不是问题。小编整理了一份关于算法的秘笈,需要的朋友关注转发后点点我即可获得免费下载方式

    高阶算法类型

    二分算法

    又叫折半查找,要求待查找的序列有序。每次取中间位置的值与待查关键字比较,如果中间位置的值比待查关键字大,则在前半部分循环这个查找的过程,如果中间位置的值比待查关键字小,则在后半部分循环这个查找的过程。直到查找到了为止,否则序列中没有待查的关键字。

    宅家三个月吃透算法笔记,面试字节,面试官朝我比了个“ok”

    冒泡排序算法

    比较前后相邻的二个数据,如果前面数据大于后面的数据,就将这二个数据交换。这样对数组的第 0 个数据到** N-1 个数据进行一次遍历后,最大的一个数据就“”到数组第N-1 个位置。N=N-1**,如果 N 不为 0 就重复前面二步,否则排序完成。

    宅家三个月吃透算法笔记,面试字节,面试官朝我比了个“ok”

    归并排序算法

    归并(Merge)排序法是将两个(或两个以上)有序表合并成一个新的有序表,即把待排序序列分为若干个子序列,每个子序列是有序的。然后再把有序的序列合并为整体有序序列。

    宅家三个月吃透算法笔记,面试字节,面试官朝我比了个“ok”

    桶排序算法

    桶排序的基本思想是: 把数组 arr 划分为 n 个大小相同的区间(桶),每个子区间各自排序,最后合并 。计数排序是桶排序的一种特殊情况,可以把计数排序当成每个桶里只有一个元素的情况。

    1. 1.找出待排序数组中的最大值 max、最小值 min
    2. 2.我们使用 动态数组 ArrayList 作为桶,桶里放的元素也用 ArrayList 存储。桶的数量为(max�min)/arr.length+1
    3. 3.遍历数组 arr,计算每个元素 arr[i] 放的桶
    宅家三个月吃透算法笔记,面试字节,面试官朝我比了个“ok”

    基数排序算法

    将所有待比较数值(正整数)统一为同样的数位长度,数位较短的数前面补零。然后,从最低位开始,依次进行一次排序。这样从最低位排序一直到最高位排序完成以后,数列就变成一个有序序列。

    宅家三个月吃透算法笔记,面试字节,面试官朝我比了个“ok”

    剪枝算法

    在搜索算法中优化中,剪枝,就是通过某种判断,避免一些不必要的遍历过程,形象的说,就是剪去了搜索树中的某些“枝条”,故称剪枝。应用剪枝优化的核心问题是设计剪枝判断方法,即确定哪些枝条应当舍弃,哪些枝条应当保留的方法。

    宅家三个月吃透算法笔记,面试字节,面试官朝我比了个“ok”

    另外PDF还包含了

    玩转算法必备基础

    算法的设计基础

    宅家三个月吃透算法笔记,面试字节,面试官朝我比了个“ok”

    算法设计的常用思想

    宅家三个月吃透算法笔记,面试字节,面试官朝我比了个“ok”

    三个水桶等分八升水问题

    宅家三个月吃透算法笔记,面试字节,面试官朝我比了个“ok”

    妖怪与和尚过河问题

    宅家三个月吃透算法笔记,面试字节,面试官朝我比了个“ok”

    最后

    两份PDF已经被小编整理好了,需要186道高阶面试题算法学习资料的朋友关注、转发,然后点点我
    即可免费获取下载方式**

    宅家三个月吃透算法笔记,面试字节,面试官朝我比了个“ok”

    相关文章

      网友评论

        本文标题:疫情划水,宅家3个月吃透算法笔记后打开了“字节跳动新世界”

        本文链接:https://www.haomeiwen.com/subject/lyjqnhtx.html