算法学习笔记

1. 动态规划

动态规划要考虑状态表示和状态计算,状态的表示分为属性和转移,计算就是实际的状态转移方程。

在考虑这种问题的时候关键考虑我们是想要什么,比如想要从0到n的最优,那可能的方法就是从0到k的最优,到k+1的最优,直到到n的最优。

2.归并排序

归并排序是把大的排序划分成两个等大的小的排序,在排序大的时候假设小的已经排序好了,使用了递归的方法来解决分解问题的思路,同时因为每次都是二分,这样问题不会出现退化成没有优化效果的逐个排序。

3.广度优先搜索

广度优先搜索一般是用队列采用先进先出的方法逐层的访问,这个比较有特点,深度优先搜索本质上是用栈,不过大多数情况下利用递归,实际上是利用了内存提供的栈,仍然是在用栈实现。

4.双指针

双指针可以解决的一种问题,比如窗口的问题,一个指向窗口的尾部一个指向窗口初始位置,在不符合条件的时候移动后面的指针,快慢指针解决的问题还有比如链表里的一些问题。

5.vector和int*的区别

数组和vector的区别是vector可以动态的变化,可以设置非常量个的,对于数组往往得自己写一个const int N

6.优先队列

使用优先队列,最小优先和最大优先可以获得最大的k个数和最小的k个数,priority_queue。

相关推荐
wuweijianlove29 分钟前
算法复杂度估算的实验建模与可视化表达的技术6
算法
执笔画流年呀30 分钟前
7大排序算法
java·算法·排序算法
AI成长日志35 分钟前
【算法学习专栏】动态规划基础·中等两题精讲(198.打家劫舍、322.零钱兑换)
学习·算法·动态规划
计算机安禾38 分钟前
【数据结构与算法】第28篇:平衡二叉树(AVL树)
开发语言·数据结构·数据库·线性代数·算法·矩阵·visual studio
测试_AI_一辰38 分钟前
AI 如何参与 Playwright 自动化维护:一次自动修复闭环实践
人工智能·算法·ai·自动化·ai编程
tq10861 小时前
价值:社会对劳动所产生的效用增量形成的局部共识
笔记
未来之窗软件服务1 小时前
算法设计—计算机等级考试—软件设计师考前备忘录—东方仙盟
算法·软件设计师·计算机等级考试
未来之窗软件服务1 小时前
哈夫曼树构造—计算机等级考试—软件设计师考前备忘录—东方仙盟
算法·软件设计师·计算机等级考试·仙盟创梦ide·东方仙盟
A923A1 小时前
【小兔鲜电商前台 | 项目笔记】第八天
前端·vue.js·笔记·项目·小兔鲜
SUNNY_SHUN2 小时前
VLM走进农田:AgriChat覆盖3000+作物品类,607K农业视觉问答基准开源
论文阅读·人工智能·算法·开源