自定义博客皮肤VIP专享

*博客头图:

格式为PNG、JPG,宽度*高度大于1920*100像素,不超过2MB,主视觉建议放在右侧,请参照线上博客头图

请上传大于1920*100像素的图片!

博客底图:

图片格式为PNG、JPG,不超过1MB,可上下左右平铺至整个背景

栏目图:

图片格式为PNG、JPG,图片宽度*高度为300*38像素,不超过0.5MB

主标题颜色:

RGB颜色,例如:#AFAFAF

Hover:

RGB颜色,例如:#AFAFAF

副标题颜色:

RGB颜色,例如:#AFAFAF

自定义博客皮肤

-+
  • 博客(17)
  • 收藏
  • 关注

原创 【C++动态规划学习总结】

1.动态规划:初识动态规划(英语:Dynamic programming,简称 DP),是一种在数学、管理科学、计算机科学、经济学和生物信息学中使用的,通过把原问题分解为相对简单的子问题的方式求解复杂问题的方法。动态规划常常适用于有重叠子问题和最优子结构性质的问题。实际上是对暴力递归的一种优化,把已经计算过的信息保存起来,下次要用时不用重复计算,并且通过求解动态数组的方式代替了函数的递归调用。第一步优化在于对计算结果的存储,避免重复计算。可以优化成下面描述的记忆化搜索方法。第二步优化在于对递归函

2022-05-26 20:47:50 429

原创 【C++ Morris算法遍历二叉树】

Morris遍历二叉树:指针建立:左子树最右结点指向当前结点,第二次访问该结点时还原,指向null结点访问过程:Morris算法流程:1.如果当前结点没有左树,则当前结点右移,如果也没有右树,则右移后当前结点为空,直接退出2.当前结点有左树时,遍历到左树的最右结点.2.1 如果是第一次来到左子树最右结点,则将其右指针指向cur结点,cur左移(一次性将左子树上的回溯指针建立好)2.2 如果第二次来到左子树最右结点,则将指针还原为空。cur右移(该左树已访问完成,继续到右树上遍历)代码:

2022-05-23 15:29:40 209

原创 【C++二叉树节点间的最大距离问题】

要点:学习树形dp套路:分析可能性–>左子树、右子树、整棵树的角度考虑用递归先要左树信息和右数信息,然后再根据这些信息更新当前结点的信息TIPS:1.一定要注意递归时辅助变量的更新问题,此处qu不带引用会使初始化二叉树出错。2.当前最大距离等于左树最大距离、右树最大距离、左右树高度和加一代码:参靠左神代码编写#include <iostream>#include <queue>using namespace std;struct Node //二叉树

2022-05-19 20:51:36 284

原创 【C++Manacher算法】

Manacher算法:Manachar算法主要是处理字符串中关于回文串的问题的,它可以在 O(n) 的时间处理出以字符串中每一个字符为中心的回文串半径,由于将原字符串处理成两倍长度的新串,在每两个字符之间加入一个特定的特殊字符,因此原本长度为偶数的回文串就成了以中间特殊字符为中心的奇数长度的回文串了TIPS:代码:参考左神代码编写#include <iostream>#include <string>#include <vector>using nam

2022-05-13 13:46:05 325

原创 【C++KMP算法】

KMP算法:KMP算法是一种改进的字符串匹配算法。KMP算法的关键是利用匹配失败后的信息,尽量减少模式串与主串的匹配次数以达到快速匹配的目的。–百度百科解释算法过程:1.算法分为两步,一步用于得到next数组,一步用于字符串比对2.获得next数组时,类似于递推式的方式。先给出两个初始值next[0],next[1],然后计算i的next值时,在前一位置的基础上进行比较,比较成功则i位置的值直接加一。否则往前跳转,直到找到匹配值或者跳到首位置(next[i]=0)3.对比时,相同则两个指针同时后

2022-05-12 16:21:16 672

原创 【C++岛问题】

题目:数组中相邻的1组成一个岛,求一个二维数组中岛的个数:例如:下面矩阵岛数为40, 0, 1, 0, 1, 0,1, 1, 1, 0, 1, 01, 0, 0, 1, 0, 00, 0, 0, 0, 1, 1TIPS:感染过程用递归法进行实现二维数组指针int(*p)[] 需要打括号,int *p[]表示指针类型的数组代码:参考左神代码编写:#include <iostream>using namespace std;void infect(int (*p)

2022-05-10 22:20:35 503

原创 【C++前缀树学习记录】

前缀树:Trie树,即字典树,又称单词查找树或键树,是一种树形结构,是一种哈希树的变种。典型应用是用于统计和排序大量的字符串(但不仅限于字符串),所以经常被搜索引擎系统用于文本词频统计。它的优点是:利用字符串的公共前缀来减少查询时间,最大限度地减少无谓的字符串比较。前缀树的3个基本性质:1.根节点不包含字符,除根节点外每一个节点都只包含一个字符。2.从根节点到某一节点,路径上经过的字符连接起来,为该节点对应的字符串。3.每个节点的所有子节点包含的字符都不相同。Trie的核心思想是空间换时间。利用

2022-04-27 21:00:24 909

原创 【C++二叉树中两节点的最近公共祖先】

题目要求:给出二叉树的头结点和树上的两个节点,返回这两个节点最近的公共节点思路:递归套路:左树上返回需要的信息,右树上返回需要的信息,然后再根据头结点的信息返回当前节点的信息(类似于后序遍历的返回方式)代码参考左神代码编写#include <iostream>using namespace std;struct Node{ int value; Node *left; Node *right; Node() : value(0), left(n

2022-04-25 15:44:44 1317

原创 【C++二叉树的序列化和反序列化】

二叉树序列化和反序列化:预期目标:序列化:将链表化为类似于1_2_##3##_的形式,#代表指针指向为空。反序列化:将序列化后的数据还原为二叉树要点:1.数据类型转换:int -> string 、string -> int 分别用to_string 和 atoi(x.c_str())实现2.序列化后数据用队列储存,不使用下标取值,方便运用递归方法。3.将string数据分解为子string问题。代码:参考左神代码编写#include <iostream>

2022-04-25 00:11:23 1925

原创 【C++判断二叉树是否为搜索二叉树、完全二叉树和平衡二叉树】

判断二叉树是否为搜索二叉树和完全二叉树:搜索二叉树:若它的左子树不空,则左子树上所有结点的值均小于它的根结点的值; 若它的右子树不空,则右子树上所有结点的值均大于它的根结点的值完全二叉树:叶子结点只能出现在最下层和次下层,且最下层的叶子结点集中在树的左部代码:参考左神代码编写#include <iostream>#include <queue>using namespace std;struct Node{ int value; Node *le

2022-04-19 22:32:07 1627

原创 【C++二叉树创建和遍历】

学习内容:分别用递归和非递归实现二叉树的先序,中序,后序遍历二叉树的创建先序:头左右中序:左头右后序:左右头要点:递归方式遍历时,先序是第一次进入函数就打印,先打印的是头结点然后再打印左节点和右节点。中序是第一次回到函数时打印,此时左节点已经打印,当前打印的是头结点,之后再打印右节点。后序是第二次回到函数时打印,此时左右节点都已打印,当前打印的是头结点。 1 / \ 2

2022-04-18 22:54:35 3865 1

原创 【Leetcode两数相加】

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档Leetcod刷题记录前言一、pandas是什么?二、使用步骤1.引入库2.读入数据总结前言提示:这里可以添加本文要记录的大概内容:例如:随着人工智能的不断发展,机器学习这门技术也越来越重要,很多人都开启了学习机器学习,本文就介绍了机器学习的基础内容。提示:以下是本篇文章正文内容,下面案例可供参考一、pandas是什么?示例:pandas 是基于NumPy 的一种工具,该工具是为了解决数据分析任务而创建的。二、使用步骤.

2022-04-12 11:30:34 931

原创 【C++堆排序学习总结】

算法图解:代码可理解为二叉树中的冒泡法。参考左神代码编写#include <iostream>using namespace std;void swap(int arr[], int index1, int index2){ int temp; temp = arr[index1]; arr[index1] = arr[index2]; arr[index2] = temp;}void show(int a[], int len){

2022-04-07 14:10:40 1019

原创 【C++快速排序学习总结】

算法图解:情况1:当前值小于所指向值情况2:当前值大于所指向值情况3:当前值等于所指向值代码遇到的问题:partition返回中间段的左右边界数据,选用结构体进行返回参考左神代码编写#include <iostream>#include <ctime>using namespace std;struct mydata{ int position1 = 0; //The left border of the middle area in

2022-04-01 11:09:10 688

原创 【C++归并排序学习总结】

学习总结:归并排序图解:–图片来自必应图片搜素小技巧:M = L + ((R - L) >> 1);//求两数平均值,可避免数据溢出代码实现参考左神代码编写学习视频地址#include <iostream>using namespace std;void merge(int arr[], int L, int M, int R){ int *temp = new int[R - L + 1]; // store temporary sorted a

2022-03-31 12:58:04 626

原创 【C++指针偏移问题】

学习记录:练习选择排序遇到的指针偏移问题问题描述数组首地址偏移a+1与&a+1效果不同,前者是指针指向数组中下一元素(数组元素地址指针),后者是指向下一数组(数组指针)//数组元素偏移int main(){ int a[]={5,5,8,4,6,9,3}; int *p1=a; int *p2=(int *)(a+1); cout<<"p1="<<p1<<endl<<"*p1="<<*p

2022-03-29 13:39:07 1868

原创 【C++中传递数组到函数时求数组长度问题】

学习记录:最近学习c++时遇到传递数组到函数的问题,将数组作为实参传递给函数时,传递的是数组首地址,对形参使用sizeof()函数会返回数组变量的字节长度。解决办法为:问题描述学习场景:学习左神刷题挑战时,练习选择排序时遇到:#include<iostream>using namespace std;class Mysort{ public: void Dosort(int a[],int len);};void Mysort::Dosort(int a[

2022-03-29 10:59:51 1401

空空如也

空空如也

TA创建的收藏夹 TA关注的收藏夹

TA关注的人

提示
确定要删除当前文章?
取消 删除