数据结构与算法面试

1、链表反转

需要三个指针,一个pre指针指向反转的前一个节点,cur指向要反转的节点,然后设置有一个temp指针指向需要反转的下一个节点,用来使得cur指针移动,因为我们反转之后,无法使用next指针访问到后一个节点

2、数组实现队列

1、入队

2、出队

1、冒泡排序

比较相邻的元素,如果前一个比后一个大,就把它们两个调换位置。对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对。这步做完后,最后的元素会是最大的数。针对所有的元素重复以上的步骤,除了最后一个。持续每次对越来越少的元素重复上面的步骤,直到没有任何一对数字需要比较。注意:第二个for循环j < length - i - 1要注意哦

2、快排

1)从序列中挑出一个元素,作为"基准"(pivot).

2)把所有比基准值小的元素放在基准前面,所有比基准值大的元素放在基准的后面(相同的数可以到任一边),这个称为分区(partition)操作。

3)对每个分区递归地进行步骤1~2,递归的结束条件是序列的大小是0或1,这时整体已经被排好序了。

相关推荐
Engineer邓祥浩26 分钟前
知识点1 时间复杂度、空间复杂度
java·数据结构·算法
博界IT精灵32 分钟前
森林和二叉树的转换(哈喜老师)
数据结构
Severus_black1 小时前
算法题C——用队列实现栈/用栈实现队列
c语言·数据结构·算法·链表
神明不懂浪漫1 小时前
【第一章】数据结构——预备知识
开发语言·数据结构·经验分享·笔记
承渊政道1 小时前
【递归、搜索与回溯算法】(掌握记忆化搜索的核心套路)
数据结构·c++·算法·leetcode·macos·动态规划·宽度优先
Little At Air1 小时前
C++priority_queue模拟实现
开发语言·数据结构·c++
xieliyu.2 小时前
Java手搓数据结构:从零模拟实现顺序表增删改查
java·开发语言·数据结构·学习·顺序表
我不是懒洋洋2 小时前
【数据结构】二叉树-堆(树的概念、二叉树的概念、顺序结构的结构及实现、堆的实现、堆排序、TopK问题)
c语言·数据结构·c++·经验分享·算法·青少年编程
KobeSacre2 小时前
将有序数组转换为二叉搜索树
数据结构·算法·leetcode
不爱吃炸鸡柳12 小时前
数据结构精讲:树 → 二叉树 → 堆 从入门到实战
开发语言·数据结构