Java语言面试-数据结构和算法相关面试

一、数组和链表的区别
1、数组是将元素在内存中连续存放,由于每个元素占用内存相同,可以通过下标迅速访问数组中任何元素。但是如果要在数组中增加一个元素,需要移动大量元素,在内存中空出一个元素的空间,然后将要增加的元素放在其中。同样的道理,如果想删除一个元素,同样需要移动大量元素去填掉被移动的元素。如果应用需要快速访问数据,很少或不插入和删除元素,就应该用数组。
2、链表恰好相反,链表中的元素在内存中不是顺序存储的,而是通过存在元素中的指针联系到一起。比如:上一个元素有个指针指到下一个元素,以此类推,直到最后一个元素。如果要访问链表中一个元素,需要从第一个元素开始,一直找到需要的元素位置。但是增加和删除一个元素对于链表数据结构就非常简单了,只要修改元素中的指针就可以了。如果应用需要经常插入和删除元素你就需要用链表数据结构了。

二、二叉树的深度优先遍历和广度优先遍历的具体实现
参考答案:https://blog.csdn.net/weixin_39912556/article/details/82852749
三、堆的结构
四、堆和树的区别
五、堆和栈在内存中的区别是什么(解答提示:可以从数据结构方面以及实际实现方面两个方面去回答)?
六、什么是深拷贝和浅拷贝
七、手写链表逆序代码
八、讲一下对树,B+树的理解
九、讲一下对图的理解
十、判断单链表成环与否?
十一、链表翻转(即:翻转一个单项链表)
十二、合并多个单有序链表(假设都是递增的)
十三.设计移动端的联系人存储与查询的功能,要求快速搜索联系人,可以用到哪些数据结构?数据库索引,平衡二叉树(B树、红黑树)
十四.红黑树特点
十五、手写算法(选择冒泡必须要会)
十六、栈与队列的区别:

  1. 队列先进先出,栈先进后出

  2. 对插入和删除操作的"限定"。 栈是限定只能在表的一端进行插入和删除操作的线性表。 队列是限定只能在表的一端进行插入和在另一端进行删除操作的线性表。

  3. 遍历数据速度不同

栈只能从头部取数据,也就最先放入的需要遍历整个栈最后才能取出来,而且在遍历数据的时候还得为数据开辟临时空间,保持数据在遍历前的一致性。

队列则不同,它基于地址指针进行遍历,而且可以从头或尾部开始遍历,但不能同时遍历,无需开辟临时空间,因为在遍历的过程中不影像数据结构,速度要快的多

十七、快排、堆排序为首的各种排序算法

十八、链表的各种操作:判断成环、判断相交、合并链表、倒数K个节点、寻找成环节点

十九、二叉树、红黑树、B树定义以及时间复杂度计算方式

二十、动态规划、贪心算法、简单的图论

二十一、排序算法有哪些?

二十二、最快的排序算法是哪个?

二十三、手写一个冒泡排序

手写快速排序代码

快速排序的过程、时间复杂度、空间复杂度

手写堆排序

堆排序过程、时间复杂度及空间复杂度

写出你所知道的排序算法及时空复杂度,稳定性

二叉树给出根节点和目标节点,找出从根节点到目标节点的路径

给阿里2万多名员工按年龄排序应该选择哪个算法?

GC算法(各种算法的优缺点以及应用场景)

蚁群算法与蒙特卡洛算法

子串包含问题(KMP 算法)写代码实现

一个无序,不重复数组,输出N个元素,使得N个元素的和相加为M,给出时间复杂度、空间复杂度。手写算法

万亿级别的两个URL文件A和B,如何求出A和B的差集C(提示:Bit映射->hash分组->多文件读写效率->磁盘寻址以及应用层面对寻址的优化)

百度POI中如何试下查找最近的商家功能(提示:坐标镜像+R树)。

两个不重复的数组集合中,求共同的元素。

两个不重复的数组集合中,这两个集合都是海量数据,内存中放不下,怎么求共同的元素?

一个文件中有100万个整数,由空格分开,在程序中判断用户输入的整数是否在此文件中。说出最优的方法

一张Bitmap所占内存以及内存占用的计算

2000万个整数,找出第五十大的数字?

烧一根不均匀的绳,从头烧到尾总共需要1个小时。现在有若干条材质相同的绳子,问如何用烧绳的方法来计时一个小时十五分钟呢?

求1000以内的水仙花数以及40亿以内的水仙花数

5枚硬币,2正3反如何划分为两堆然后通过翻转让两堆中正面向上的硬8币和反面向上的硬币个数相同

时针走一圈,时针分针重合几次

N*N的方格纸,里面有多少个正方形

x个苹果,一天只能吃一个、两个、或者三个,问多少天可以吃完?

五十八.冒泡算法:
https://www.jianshu.com/p/ae97c3ceea8d

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值