E-COM-NET
首页
在线工具
Layui镜像站
SUI文档
联系我们
推荐频道
Java
PHP
C++
C
C#
Python
Ruby
go语言
Scala
Servlet
Vue
MySQL
NoSQL
Redis
CSS
Oracle
SQL Server
DB2
HBase
Http
HTML5
Spring
Ajax
Jquery
JavaScript
Json
XML
NodeJs
mybatis
Hibernate
算法
设计模式
shell
数据结构
大数据
JS
消息中间件
正则表达式
Tomcat
SQL
Nginx
Shiro
Maven
Linux
数据结构学习-图论基础
数据结构学习
jz43 数字 1 的个数
关键词:数位dp记忆化搜索dfs专门写了数位dp的笔记,里面的第一题和这个是一模一样的。建议直接看链接。题目:复杂度计算:时间复杂度O(log^2n)时间复杂度=状态个数*单个状态的转移次数,状态个数就是dp数组的长度,即O(log^2n),而单个状态的转移次数=O(10)=O(1),所以时间复杂度为O(log^2n)空间复杂度O(log^2n)代码:classSolution{public:in
_Rindo
·
2024-01-15 14:36
数据结构学习
数据结构
学习
深度优先
数据结构学习
jz14剪绳子
关键词:数学动态规划快速幂这道题其实是分为两题。题目一:这道题我是没有思路的,看了k神的答案才知道有数学的方法。方法一:数学:其实中间的推导我没看,我服了。思路:复杂度计算:时间复杂度O(1)空间复杂度O(1)代码:看了k神的答案自己写的classSolution{public:intcuttingBamboo(intbamboo_len){if(bamboo_lendp(bamboo_len+1
_Rindo
·
2024-01-15 14:36
数据结构学习
数据结构
学习
数据结构学习
jz19正则表达式匹配
关键词:动态规划这题确认dp状态不难,最关键也是最麻烦的是找到正确的转移方程。我参考了这位大神的答案。题目:思路:dp状态:dp[i][j]:代表字符串s的前i个字符和p的前j个字符能否匹配。(注意这里dp的第0行和第0列表示s为空和p为空的情况)初始状态:dp[0][0]=1因为空字符串和空字符串可以匹配如下表格所示‘’.*a‘’1000b0000c0000a0000转移方程:假如我们需要确认d
_Rindo
·
2024-01-15 14:06
数据结构学习
学习
数据结构学习
jz44 数字序列中某一位的数字
关键词:找规律数学题目:LCR163.找到第k位数字虽然做出来了但是做了十万年,我是猪。主要还是找到准确的规律。思路://找规律//0-9占了10个位置//10-99占了90*2个位置//100-999占了900*3个位置//1000-9999占了9000*4个位置总体求解顺序:1、确定要求的数字的位数2、再确定数字3、再确定要求的数字的第b位比如:k==4791、确定要求的数字的位数479-10
_Rindo
·
2024-01-15 14:29
数据结构学习
学习
【数据结构之堆的实现】
数据结构学习
笔记---008数据结构之堆1、堆的概念和结构1.1、如何实现堆?
下课后泡实验室
·
2024-01-15 07:15
数据结构
数据结构
笔记
堆
小根堆
大根堆
堆的基本操作
二叉树
数据结构学习
之对单向链表进行快速高效的排序(排序链表)
实例要求:1、给定一个链表的头结点head,请将其按升序排列并返回排序后的链表;2、链表中节点的数目的范围为[0,5*104];实例分析:1、引入qsort函数和自定义cmp函数解决问题;2、借助自定义指针作为中间量,将链表节点的值依次赋值;3、排序结束后,再将指针保存的链表节点归位即可;4、为防止内存泄漏,需要使用free函数释放指针所占用的空间;qsort函数:voidqsort(void*b
少年维克多
·
2024-01-15 02:52
C语言学习系列
笔试题
数据结构
学习
链表
数据结构学习
之单向循环链表应用的案例(旋转链表)
实例要求:1、给定一个链表的头节点head,请你旋转链表,将链表每个节点向右移动k个位置;2、链表中节点的数目的范围为[0,500];实例分析:1、入参合理性检查,即head!=NULL||head->next!=NULL||k!=0;2、while循环找到链表的最后一个节点;3、单向链表首尾相连,形成单向循环链表,即tail->next=head;4、每个元素向右移动完成后,单向循环链表恢复为单
少年维克多
·
2024-01-15 02:22
笔试题
C语言学习系列
数据结构
学习
链表
408
数据结构学习
笔记——二叉排序树、二叉平衡树、红黑树
目录1.二叉排序树1.1.二叉排序树的基本概念1.2.二叉排序树的查找代码实现1.3.二叉排序树的插入1.4.二叉排序树的删除1.5.二叉排序树的查找效率1.6.二叉排序树的缺陷2.平衡二叉树2.1.平衡二叉树的基本概念2.2.平衡二叉树的插入2.2.1.LL型平衡旋转(中为支,高右转)2.2.2.RR型平衡旋转(中为支,高左转)2.2.3.LR型平衡旋转(下二整体先左转,后与LL同)2.2.4.
江南江南江南丶
·
2024-01-14 06:22
数据结构
数据结构
数据结构学习
笔记——查找算法中的树形查找(红黑树)
目录一、红黑树的定义(一)黑/红结点、叶子节点(二)黑色完美平衡二、红黑树的性质(一)黑高和高度(二)叶子结点个数三、红黑树与AVL对比一、红黑树的定义红黑树是一棵二叉排序树(满足结点值中:左子树<根结点<右子树),每个结点都带有颜色属性,即黑或红。可以简单地说它是一棵“平衡二叉树”,但由于它的左、右子树高度差的绝对值有可能超过1,所以并不是严格意义上的平衡二叉树,只能说是一棵弱平衡二叉树,相对于
晚风(●•σ )
·
2024-01-14 06:49
数据结构
数据结构
红黑树
平衡二叉树
AVL
查找算法
树形查找
查找
【数据结构之树和二叉树】
数据结构学习
笔记---007数据结构之树和二叉树概念篇1、树的概念和结构1.1、树的相关概念1.2、树的存储结构2、二叉树概念及结构2.1、二叉树概念2.2、满二叉树2.3、完全二叉树2.4、满二叉树或完全二叉树的存储形式
下课后泡实验室
·
2024-01-13 17:02
数据结构
数据结构
数据结构树
二叉树
森林
线索二叉树
二叉树和森林或树的转换
二叉树的性质
数据结构学习
之顺序栈应用的案例(有效的括号)
实例要求:给定一个只包括'(',')','{','}','[',']'的字符串s,判断字符串是否有效;有效字符串需满足的条件:1、左括号必须用相同类型的右括号闭合;2、左括号必须以正确的顺序闭合;3、每个右括号都有一个对应的相同类型的左括号;相关案例:实例分析:1、利用strlen函数求出该字符串长度并且定义一个顺序栈(本代码将使用一个字符型数组和整形变量替代);2、for循环遍历字符串,当遇到’
少年维克多
·
2024-01-12 22:27
笔试题
数据结构
数据结构学习
—图
1、什么是图?图是右顶点的有穷非空集合和顶点之间的集合组成,通常表示为:G(V,E),其中G表示一个图,V是图G的顶点的集合,E是图G中边的集合。我们只要记得,在图形结构中,结点之间的关系可以是任意的,因此图是多对多的关系。2、图的各种定义无向边:若顶点Vi到Vj之间的边没有方向,则称这条边为无向边,用无序偶对(Vi,Vj)来表示。如果图中任意两个顶点之间的边都是无向边,则称该图为无向图。对于无向
先弓
·
2024-01-12 15:48
9月3号
数据结构学习
笔记
为何这样写可以,因为Q.front与Q.rear本身都是一个指针,指针指的地址变了,所以会有变化。盲猜是把结构体structLinkNode命名为LinkNodestruct命名为LinkQueue对比一下单链表的操作我对初始化有点懵。我明白了,因为LinkList虽为链表本质为一个头节点,节点用*定义用->表示。而LinkQueue虽为队列,但是有两个指针需要定义,这样初始化就用这样调用。
ykzcs2000
·
2024-01-06 06:33
数据结构
学习
链表
9月2号
数据结构学习
笔记
在2.9节,我写了一个明显错误的代码,是在双链表后初始化头节点后又初始化2个节点,并且分别命名为1,2后,删除第2个节点。然后重新显示这个链表中的每一个元素,我这个display是个死循环,但是也不该出现这种显示结果。//循环单链表的初始化//#include//#include//typedefstructLNode{//intdata;//structLNode*next;//}LNode,*
ykzcs2000
·
2024-01-06 06:32
数据结构
学习
链表
数据结构学习
笔记——查找算法中的树形查找(B树、B+树)
目录前言一、B树(一)B树的概念(二)B树的性质(三)B树的高度(四)B树的查找(五)B树的插入(六)B树的删除二、B+树(一)B+树的概念(二)B+树的性质(三)B+树的查找前言B树和B+树属于树形查找算法中的一种,主要用于数据库系统、文件系统和磁盘存取等方面,都是用于存储和索引大量的数据,以提高检索效率。例如,在磁盘存储中,通过将数据分散到多个磁盘块中,并使用树形结构来组织这些磁盘块,从而提高
晚风(●•σ )
·
2024-01-05 00:11
数据结构
数据结构
查找
b树
b+树
树形查找
数据结构学习
第五章树和二叉树
第五章树和二叉树1树的定义1.1定义1.2基本术语1.3二叉树定义特点:①每个结点最多有两个孩子(二叉树中不存在度大于2的结点)。②子树有左右之分,次序不能颠倒。③二叉树可以是空集合,跟可以有空的左子树或者空的右子树。注:二叉树不是树的特殊情况,二叉树的子树要区分左子树和右子树,而树无需区分。例子:具有三个节点的二叉树有五种不同形态。树有两种形态1.4二叉树的5种形态2.树的应用案例【案例1】数据
咖啡加Ice
·
2023-12-31 12:18
咖啡ice的数据结构学习记录
数据结构
学习
软件测试/测试开发丨Python常用
数据结构学习
笔记
Python常用数据结构list列表列表定义列表是有序的可变元素的集合,使用中括号[]包围,元素之间用逗号分隔列表是动态的,可以随时扩展和收缩列表是异构的,可以同时存放不同类型的对象列表中允许出现重复元素列表使用:创建创建列表通过构造函数创建li=list()中括号创建并填充li=[1,2,3]列表推导式li=[xforxinrange(10)]列表使用:索引索引默认正向索引,编号从0开始。支持反
测试萧十一郎
·
2023-12-30 21:20
软件测试
python
数据结构
学习
功能测试
软件测试
自动化测试
程序人生
【C语言】数据结构——排序二(快排)
个人主页⭐个人专栏——
数据结构学习
⭐点击关注一起学习C语言目录导读:数组打印与交换1.交换排序1.1基本思想:1.2冒泡与快排的异同2.冒泡排序2.1基本思想2.2实现代码3.快速排序3.1基本思想3.2hoare
流浪者与猴
·
2023-12-30 07:55
数据结构学习
c语言
数据结构
排序算法
数据结构学习
--顺序表的代码实现(C++)
以下代码为使用C++完成顺序表的静态实现后面会尝试顺序表的动态实现顺序表的销毁还不会实现,待后面的深入学习再来补充#includeusingnamespacestd;#definemaxSize10structsqlList{intdata[maxSize];//静态的“数组”存放数据intlength;//顺序表的当前长度};//打印顺序表voidprintSqlList(sqlList&L){
卡夫卡是也
·
2023-12-30 02:32
数据结构
【C语言】数据结构——排序(一)
个人主页⭐个人专栏——
数据结构学习
⭐点击关注一起学习C语言目录导读:数组打印与交换1.插入排序1.1直接插入排序1.1.1基本思想1.1.2实现代码1.1.3图解1.2希尔排序1.2.1基本思想1.2.2
流浪者与猴
·
2023-12-29 06:40
数据结构学习
c语言
数据结构
排序算法
数据结构学习
Leetcode494 目标和
关键词:动态规划01背包dfs回溯一个套路:01背包:空间优化之后dp【target+1】,遍历的时候要逆序遍历完全背包:空间优化之后dp【target+1】,遍历的时候要正序遍历题目:解法一:dfs回溯思路:数组nums的每个元素都可以添加符号+或-,因此每个元素有⒉种添加符号的方法,n个数共有2^n种添加符号的方法,对应2^n种不同的表达式。当n个元素都添加符号之后,即得到─种表达式,如果表达
_Rindo
·
2023-12-28 15:03
数据结构学习
数据结构
学习
深度优先
数据结构学习
jz13衣橱整理
关键词:搜索算法dfsbfs回溯题目:各数位之和:求法代码:intsums(intx){ints=0;while(x!=0){s+=x%10;x=x/10;}returns;}总的思路:这道题是求可以到达的格子数,想到可以用搜索算法来做,可以用dfs或者bfs。可以去看这位大佬的分析。我基本是按照他的思路写的,但是把代码写的好看了一些。求各数位之和我用了封装好的sums函数,看起来舒服一些。我一开
_Rindo
·
2023-12-28 15:03
数据结构学习
数据结构
学习
深度优先
数据结构学习
Leetcode322 零钱兑换
关键词:动态规划完全背包记忆化搜索一个套路:01背包:空间优化之后dp【target+1】,遍历的时候要逆序遍历完全背包:空间优化之后dp【target+1】,遍历的时候要正序遍历题目:方法一:动态规划完全背包思路:就是一个完全背包问题。有无限个相同的硬币。目标就是amount。状态:dp[j]判断在放第i种硬币时,凑成目标金额为j所需要的最少硬币个数。(进行了滚动数组进行空间优化,正序遍历)转移
_Rindo
·
2023-12-28 15:33
数据结构学习
学习
数据结构学习
Leetcode474 一和零
关键词:动态规划01背包一个套路:01背包:空间优化之后dp【target+1】,遍历的时候要逆序遍历完全背包:空间优化之后dp【target+1】,遍历的时候要正序遍历目录题目:思路:复杂度计算:代码:题目:思路:这题能想到用01背包并正确用起来有点难哦!这里面有三样东西,一些strs,m个0和n个1。我刚开始是希望把strs当作容器,把0和1装进strs这个容器里,但是不行。转换思路:把m个0
_Rindo
·
2023-12-28 14:56
数据结构学习
数据结构
学习
数据结构学习
笔记(八)图
文章目录1.前言2.概念3图的存储结构3.1图的邻接矩阵表示3.2图的邻接表表示4.图的遍历4.1深度优先搜索4.2广度优先遍历5连通分量6最小生成树6.1Kruskal算法6.2实现6.2Prim算法7最短路径7.1dijkstra算法8用顶点表示活动的网络(AOV)9用边表示活动的网络(AOE)9.1VE事件最早发生时间9.2VL事件最晚发生时间9.3E()活动的最早发生时间9.4L()活动的
千殃sama
·
2023-12-27 12:59
数据结构
学习
笔记
数据结构学习
笔记(六)集合
文章目录1.前言2.概念2.1位向量实现集合抽象数据类型2.2有序链表实现集合的抽象数据类型3并查集与等价类3.1概念4字典4.1字典的线性表描述5跳表6.散列表6.1散列函数6.2解决冲突的方法6.2.1线性探查法6.2.2二次探查法6.2.3开散列方法1.前言本系列笔记基于清华大学出版社的《数据结构:用面向对象方法与C++语言描述》第二版进行学习。2.概念集合是成员的一个群集,集合中成员可以是
千殃sama
·
2023-12-27 12:58
数据结构
学习
笔记
数据结构学习
笔记(七)搜索结构
文章目录1.前言2.概念3静态搜索结构3.1静态搜索表3.2顺序搜索表3.2.1基于有序顺序表和顺序搜索和折半搜索4二叉搜索树4.1搜索二叉树的类定义4.2搜索二叉树的搜索4.3搜索二叉树的插入4.4搜索二叉树的删除5AVL树5.1平衡化旋转5.1.1右旋:LL型状态5.1.2左旋:RR型状态5.1.3右旋(LL)的例子5.1.4先左旋再右旋(LR)的操作5.1.5先右旋再左旋(RL)的操作5.1
千殃sama
·
2023-12-27 12:58
数据结构
学习
笔记
数据结构学习
笔记(九)排序
文章目录1.前言2.选择排序3.插入排序4.冒泡排序4.1优化5.希尔排序6.归并排序7.快速排序8.堆排序9.桶排序1.前言这部分没有基于书上学习,基于知乎上一篇文章必学十大经典排序算法,看这篇就够了基础进行学习.关于GIF都是网上搜索的,如果侵权私我我直接删除.图中所有算法都默认以从小到大的顺序排序。2.选择排序选择排序,第一步选择数组中最小的元素和数组的第一个元素进行交换,第二步不管已经交换
千殃sama
·
2023-12-27 12:26
数据结构
学习
笔记
数据结构学习
Leetcode356 俄罗斯套信封
关键词:动态规划最长递增子序列贪心二分查找其实就是最长递增子序列。比较难的是需要理解题目用并想起来用这个方法。可以看看这位大神写的方法,循序渐进,我觉得很好。里面提到的四种方法的总结就是:第一种方法就是降维(控制第一维)+最长上升子序列。第二种方法就是降维(控制第一维)+最长上升子序列+控制第二维第三种方法就是降维(控制第一维)+贪心。第四种方法就是降维(控制第一维)+贪心+二分查找。我在下面写的
_Rindo
·
2023-12-26 13:36
数据结构学习
数据结构
学习
算法
数据结构学习
Leetcode120 三角形最小路径和
动态规划线性的三种类型(除了背包问题):最长递增子序列最长公共子序列三角形最小路径和题目:思路:从上到下,找到到每个点的最优路径即可。最优路径为左上或者右上点+这个点自身的数值。图解:dp状态和转移方程:从顶点出发到某个点的最小路径和只和这个点的左上右上两个点的状态有关。而且这个状态的得到与左上右上两个点是怎么来的无关。方法一:这个方法和上面一样,但是是在三角形原地进行路径权重的累加。会破坏原来的
_Rindo
·
2023-12-26 11:47
数据结构学习
数据结构
学习
数据结构学习
Leetcode198 打家劫舍
动态结构最长上升子序列题目:解法一:思路:状态:F[i]前i间房能偷到的最大金额。转移方程:偷和不偷取最大如果不偷:F[i-1]如果偷:nums[i]+F[i-2]如果偷就不能偷前一个,所以要从F[i-2]开始选。注意这里前一个房子(i-1)偷没偷是不影响这个F[i-2]的,不管怎么样,写F[i-2]就是对的。因为:如果算F[i-1]的时候,第i-1个房子小偷决定要偷,那么理所当然地,在计算F[i
_Rindo
·
2023-12-26 11:41
数据结构学习
数据结构
学习
算法
数据结构学习
【二叉树 链式结构 C++ 先序&中序&后序&层次遍历】
数据结构学习
【二叉树链式结构C++先后中序和层次遍历】本次实现的是二叉树的链式存储结构。插入方式采用的是二叉排序树的插入方式。
toro180
·
2023-12-25 20:05
数据结构
数据结构
c++
排序算法
树结构
基于图搜索的自动驾驶规划算法 - BFS,Dijstra,A*
本文将讲解BFS,Dijstra,A*,动态规划的算法原理,不正之处望读者指正,希望有兴趣的读者能在评论区提出一些这些算法的面试考点,共同学习,一起进步0
图论基础
图有三种:无向图、有向图、带权重的图无向图有向图带权重的图
Big David
·
2023-12-25 07:57
Motion
planning
Planning模块
算法
规划算法
Astar
BFS
Dijstra
数据结构基础:P2-线性结构----编程作业02:一元多项式的乘法与加法运算
本系列文章为浙江大学陈越、何钦铭
数据结构学习
笔记,系列文章链接如下:数据结构(陈越、何钦铭)学习笔记文章目录一、题意理解与多项式表示1.1题意理解1.2多项式表示二、程序框架及读入多项式2.1程序框架2.2
爱你哦小猪猪
·
2023-12-25 06:38
数据结构基础
数据结构
c语言
算法
链表
面试
【数据结构之栈】
数据结构学习
笔记---005数据结构之栈1、栈的概念和结构1.1、如何实现栈?
下课后泡实验室
·
2023-12-24 13:02
数据结构
数据结构
笔记
栈
顺序表
单链表
C语言
学习
【数据结构之队列】
数据结构学习
笔记---006数据结构之队列1、队列的概念和结构1.1、如何实现队列?
下课后泡实验室
·
2023-12-24 13:30
数据结构
数据结构
笔记
c语言
队列
循环队列
栈实现队列
队列实现栈
数据结构学习
笔记(c语言版)
文章目录一、概念1.基本术语2.算法3.时间复杂度4.数据的逻辑结构二、线性表1.存储结构2.基本操作三、栈1.存储结构2.基本操作3.实际应用四、队列1.存储结构2.基本操作五、串1.存储结构2.基本操作六、矩阵1.存储结构七、广义表1.存储结构八、树1.存储结构九、二叉树1.存储结构2.基本操作3.实际应用十、图1.存储结构2.基本操作十一、查找十二、内部排序一、概念1.基本术语术语解释数据对
是奶酥吖_
·
2023-12-23 16:26
数据结构
c语言
【十分钟实现带头双向链表】
数据结构学习
笔记---004带头双向链表的实现1、带头双向链表的结构2、带头双向链表接口的实现2.1、带头双向链表的DDList.h2.2、带头双向链表的DDList.c2.2.1、CreatLTNode
下课后泡实验室
·
2023-12-23 13:03
数据结构
c语言
笔记
数据结构
单链表
顺序表
带头双向链表
学习
【数据结构之顺序表】
数据结构学习
笔记---002数据结构之顺序表1、介绍线性表1.1、什么是线性表?2、什么是顺序表?
下课后泡实验室
·
2023-12-23 13:02
数据结构
数据结构
笔记
顺序表
单链表
线性表
c语言
malloc函数
【数据结构之单链表】
数据结构学习
笔记---003数据结构之单链表1、什么是单链表?
下课后泡实验室
·
2023-12-23 13:02
数据结构
数据结构
单链表
顺序表
malloc
calloc
笔记
算法
C语言
【数据结构开篇 --- 时间和空间复杂度】
数据结构学习
笔记---001数据结构开篇1、介绍数据结构及算法1.1、什么是数据结构?1.2、什么是算法?2、数据结构的重要性3、如何衡量一个算法的好坏?
下课后泡实验室
·
2023-12-23 13:30
数据结构
数据结构
c语言
笔记
时间复杂度
空间复杂度
算法
学习
数据结构学习
leetcode64最小路径和
动态规划题目:建议看这里,有这道题详细的解析。我觉得写的挺好。这是我在学动态规划的时候,动手做的一道题。虽然我在学动态规划,但是我之前学了dps,所以我就想先用dps试着做,结果发现不行,原因是我的中止条件没有弄好,最终如果改成dps+memory,就会和动态规划一样了。解析:dp状态:【F(x,y)】走到(x,y)时所用的最小路径和。满足「最优子结构」和「无后效性」。dp转移方程:分类讨论的思想
_Rindo
·
2023-12-21 14:15
数据结构学习
数据结构
学习
数据结构学习
Leetcode1143最长公共子序列
动态规划最长公共子序列LCS这是我在看动态规划学习的时候做的。这是一篇LCS。LCS是两个数组进行比较。题目:思路:我觉得这个总结挺好的:求两个数组或者字符串的最长公共子序列问题,肯定是要用动态规划的。首先,区分两个概念:子序列可以是不连续的;子数组(子字符串)需要是连续的;另外,动态规划也是有套路的:单个数组或者字符串要用动态规划时,可以把动态规划dp[i]定义为nums[0:i]中想要求的结果
_Rindo
·
2023-12-21 14:15
数据结构学习
学习
数据结构学习
jz10斐波那契数列
题目:解法一:暴力递归太慢了要递归两次而且很多重复计算原理:把f(n)问题的计算拆分成f(n−1)和f(n−2)两个子问题的计算,并递归,以f(0)和f(1)为终止条件。缺点:大量重复的递归计算,例如f(n)和f(n−1)两者向下递归需要各自计算f(n−2)的值时间复杂度O(N^2)空间复杂度O(N)前后各开了一个栈给递归#include//解法一:暴力递归太慢了要递归两次//时间复杂度O(N^2
_Rindo
·
2023-12-21 14:45
数据结构学习
数据结构
学习
算法
数据结构学习
12字母迷宫
dfs回溯剪枝这个题和dfs有关,但是我之前没有接触过,我看了这一篇很好的文章,看完之后写的答案。我觉得很好的总结:dfs模板intcheck(参数){if(满足条件)return1;return0;}voiddfs(intstep){判断边界{相应操作}尝试每一种可能{满足check条件标记继续下一步dfs(step+1)恢复初始状态(回溯的时候要用到)}}尝试每一种可能,一般都是用for循环。
_Rindo
·
2023-12-21 14:45
数据结构学习
学习
数据结构学习
棋盘问题
题目:问题:在一个给定形状的棋盘(形状可能是不规则的)上面摆放棋子,棋子没有区别。要求摆放时任意的两个棋子不能放在棋盘中的同一行或者同一列,请编程求解对于给定形状和大小的棋盘,摆放k个棋子的所有可行的摆放方案C。input:输入含有多组测试数据。每组数据的第一行是两个正整数,nk,用一个空格隔开,表示了将在一个n*n的矩阵内描述棋盘,以及摆放棋子的数目。n#include//棋盘问题intn=3;
_Rindo
·
2023-12-21 14:45
数据结构学习
数据结构
学习
算法
数据结构学习
jz04二维矩阵找数字
题目:解法一:找角落点,然后渐进目标(像二叉搜索树)时间复杂度O(n+m)空间复杂度O(1)#include#include//解法一找到角落的一个点,然后渐进目标classSolution{public:boolfindTargetIn2DPlants(std::vector>&plants,inttarget){if(plants.size()==0||plants[0].size()==0)
_Rindo
·
2023-12-21 14:44
数据结构学习
数据结构
学习
矩阵
数据结构学习
jz09两个栈组成队列
题目:思路:这是一道比较简单的题目,一开始就能想到一个栈专门用来出栈,另一个栈专门用来入栈。但是我实现了之后发现时间特别慢,这让我很纳闷。后来发现有一些细节需要注意。修改了之后速度就上去了。原本的思路:在出栈和入栈的时候,我都检查了另一个栈有没有数据,如果有数据就switch_stack【注意,这是不对的】例子:先给A入栈,相当于往队列存数据。A:|1|2|3|B:||然后想要出栈,这个时候需要把
_Rindo
·
2023-12-21 14:44
数据结构学习
数据结构
学习
算法
数据结构学习
快速排序
网上的图有点看不懂,所以按照自己的理解画了一个。平均时间复杂度:O(NlogN)最佳时间复杂度:O(NlogN)最差时间复杂度:O(N^2)空间复杂度:根据实现方式的不同而不同排序方式:In-place稳定性:不稳定写的时候踩了俩坑,好在还是发现了。#include#includevoidQuickSort(intarr[],size_tl,size_tr){if(r==0||l>=r-1)ret
_Rindo
·
2023-12-21 14:14
数据结构学习
数据结构
学习
算法
数据结构学习
Leetcode300最长递增子序列
是我在学习动态规划时遇到的一道题。题目:一共有两种解法:动态规划贪心二分(很难理解,我还没完全懂。。。)解法一:动态规划思路:状态:nums的前i个数的最长递增子序列。dp[i]转移方程:依次计算每个状态dp[i]的状态,这个状态依赖于前dp[0...i-1]的状态。如果大于前面的数nums[j]6,所以dp[7]=dp[3]+1然后又和0比,7>0,如果直接dp[7]=dp[4]+1,那么dp[
_Rindo
·
2023-12-21 13:39
数据结构学习
数据结构
学习
上一页
1
2
3
4
5
6
7
8
下一页
按字母分类:
A
B
C
D
E
F
G
H
I
J
K
L
M
N
O
P
Q
R
S
T
U
V
W
X
Y
Z
其他