自定义博客皮肤VIP专享

*博客头图:

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

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

博客底图:

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

栏目图:

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

主标题颜色:

RGB颜色,例如:#AFAFAF

Hover:

RGB颜色,例如:#AFAFAF

副标题颜色:

RGB颜色,例如:#AFAFAF

自定义博客皮肤

-+
  • 博客(20)
  • 资源 (1)
  • 收藏
  • 关注

原创 ACM算法基础-kmp算法详解

问题背景:kmp算法最直接的引用就是模式串和文本串的匹配,我们假设直接用暴力的方法进行匹配的话,方法很简单,就是两个指针,i指针最初指向文本串的起始位置,j指针最初指向模式串的起始位置,然后从文本串的起始位置开始每一位与模式串的每一位进行匹配,如果每一位都是相同的话,那么就继续匹配下一位,当我们只要匹配到有一位是不相等的时候,我们就将文本串的起始位置变成i1,然后继续从模式串的起始位置开始匹配,假设模式串和文本串的长度分别是n和m,时间复杂度是O(n*m)​,暴力确实太可怕了。

2021-10-03 16:20:23 10070 13

原创 中缀表达式转后缀表达式C++实现

中缀表达式转后缀表达式也是近年来找工作笔试、面试、考研机试,算法竞赛中的考点,所以学会它也是很有必要的,因为这种问题的代码比较模板化,建议读者直接背诵模板,但是不能死记硬背,而是在理解算法思路的基础上背诵此代码。

2024-01-30 22:58:02 924 1

原创 机器学习入门博客(吴恩达机器学习课程总结)

机器学习入门教程,根据吴恩达机器学习课程总结,旨在帮助广大朋友由浅入深学习机器学习

2024-01-29 18:34:25 1184

原创 表达式求值C++实现

表达式求值这个知识点在最近几年的找工作笔试、面试,考研机试,各种算法竞赛笔试中出现的频率越来越高了;但是以前从来没有见过这种题要想在笔试面试中写出来不是一件简单的事情,网络上面大部分代码不够精炼,不方便理解和背诵模板;本篇博客提供了表达式求值的一道经典模板题,从理解表达式求值思路到整个代码模板,方便大家理解和背诵;旨在帮助广大笔试面试的朋友轻松应对此类问题。

2024-01-28 21:10:31 1585

原创 ACM算法基础-并查集详解

并查集并查集的作用:1:将两个集合合并成一个集合2:询问两个元素是否在同一个集合中存储的方式:我们用树的形式来维护所有的集合,每个集合用一颗树来表示树中根节点的编号就是该集合的编号用一个fa[]fa[]fa[]数组来存储每一个点的父亲结点问题:如何判断树根?x=fa[x]x=fa[x]x=fa[x];如何判断每一个点所在的集合编号 while(x!=fa[x])x=fa[x]while(x!=fa[x]) x=fa[x]while(x!=fa[x])x=fa[x];如何合并两个集合?将

2021-10-05 14:42:00 735 1

原创 详解单调栈和单调队列问题

单调栈题目背景:假定有一个序列,现在我需要你来求每一个数左边离他最近的且比它小的数,如果存在的话,就输出这个数,如果不存在的话,我们就输出-1。其实这道题的暴力思路是特别简单的,直接两重循环,外面那重循环相当于遍历序列的每一个数,内层循环相寻找比外层循环指的那个数小的数,其实我们可以把这个操作直接想象成一个栈,当外层循环i指向一个数时,相当于已经将a[1]a[1]a[1]​​,a[2]a[2]a[2]​…… a[i−1]a[i-1]a[i−1]​加入到栈里面,然后满足条件的数就是栈顶元素(因为栈顶元素

2021-10-03 13:51:27 196

原创 ACM算法基础-离散化算法详解

离散化算法离散化使用的范围首先给你一个序列,我们有一些数值,这些数值的范围比较大,值域可能是[0,109][0,10^9][0,109],但是里面的个数是很少的,个数可能是[0,105][0,10^5][0,105]​,有些时候我们需要利用这些值当作数组的下标来做,这是我们是不可能去开一个10910^9109​的数组的,因此,我们就要将这个序列里面的数映射到一个从0开始的连续自然数。但是在离散化的时候我们应该注意哪一些问题呢?(1)序列里面的元素有可能是重复\color{red}{重复}重复​​​的

2021-09-28 11:21:49 3690 4

原创 差分解题详解(通俗易懂,包括二维差分)

差分解题详解差分的定义给你一组数据a1a2a3……ana1 a2 a3 …… ana1a2a3……an​​,你需要构造一个数组使得b1b2b3……bnb1 b2 b3 …… bnb1b2b3……bn​,使得bbb​数组的前缀和是aaa​.(注意:b数组是自己需要构造的)b1=a1b1=a1b1=a1b2=a2−a1b2=a2-a1b2=a2−a1………bn=an−an−1bn=an-an-1bn=an−an−1​a数组就称为b的前缀和,b数组就称为a的差分。何时可以用到差分我们有了b数组,

2021-09-26 10:17:06 513

原创 最强详解高精度减法

高精度减法模板适用的前提计算A-B的时候,当A的位数和B的位数都很大的时候,它就派上用场了。通用的模板有一下几个条件:1:A和B都是正数2:A>=B;疑问???当A和B中有负数的时候,我们是不是不能采用这个模板呢?其实这并不是模板的问题,而是我们在读入数据的时候我们需要分类讨论,以下就是分类讨论的几种情况:{−(∣A∣+∣B∣)A<0,B>0A<0,B<0{−(∣A∣−∣B∣)∣A∣>∣B∣∣B∣−∣A∣∣A∣<∣B∣∣A∣+∣B∣A>0,B&l

2021-09-16 21:47:27 202

原创 逆元的求解

求解逆元的思路1:什么是逆元如果两个数相乘对mmm取模等于1,则称这两个数互为逆元。2:费马小定理如果mmm是素数,aaa是任意数,则有am−1a^{m-1}am−1≡1(mmm);接下来根据逆元的定义则有aaa*am−2a^{m-2}am−2≡1(mmm);所以aaa%mmm的逆元就是am−2a^{m-2}am−2%mmm;am−2a^{m-2}am−2用快速幂来求解#include<iostream>#include<algorithm>using names

2021-09-13 23:40:43 222

原创 快速幂详解

快速幂的一些理解什么是快速幂当我们需要求解aba^bab​​,当bbb​​特别大的时候,我们求aba^bab​​是在复杂度为bbb​​内求出来的,有没有更加快的方法呢?能不能在logblog blogb​​的时间复杂度内求出来,当然是可以的,那就是用快速幂的方法。快速幂的求解步骤​a20a^{2^0}a20​​a21a^{2^1}a21a22a^{2^2}a22……a2logba^{2^{logb}}a2logb​我们发现其实求解的每一个指数都是2i2^i2i​​,iii​​其实是将十进制

2021-09-13 21:02:11 98

原创 Educational Codeforces Round 113 (Rated for Div. 2) 题解

[Educational Codeforces Round 113 (Rated for Div. 2)]题解A Balanced Substring题目大意:给你一个长度为n只含有a,b的字符串,字符串的长度从1-n,现在你需要找到一个平衡的字串(这个字串中a的个数是等于b的个数),如果这样的字串存在的话输出字串起点和终点的下标,没有的话输出-1 -1;解题思路:利用两层循环,外层循环代表寻找字串的起点的下标,内层循环表示终点的下标,如果找到了的话就将下标记录退出循环并输出,否则输出-1 -1。

2021-09-09 23:35:48 150

原创 用命令行的方式才运行c/c++程序(精准的测量程序运行的时间)

用命令行的方式才运行c/c++程序下面演示的是vs2019如何运行比如我运行的程序文件全部放在e盘1 e: 按enter2 cd (找到那个带.exe所在的目录,复制粘贴到上面)3 echo (输入程序的东西) | 文件名.exe这里的echo 51200 | Project1.exe 的含义是操作系统会自动将51200输入,这个在测试时间的时候就会非常的精准,如果不用这个的话,那么在计算时间的时候键盘输入的时间也会被计算在内,Project1.exe是程序名。cd 表示转换目录 c

2021-09-08 12:00:12 289

原创 Chinese Mahjong(中国麻将)题解

Chinese Mahjong1:每次读入13张牌,然后我们从34张牌中依次选取一张牌,看是否听这张牌,是否听这张牌,我们可以直接将这张牌直接加入到原来的13张牌中,看是否可以胡牌就行。2:现在我们来思考一下递归的过程,首先我们选出两张牌作为对子,当这张牌的张数大于等于2的时候,将这张牌拥有的张数减去2,假如我们有多张牌可以作为将,我们一次之选其中一张,其他的牌作为刻子或者是顺子。然后选出3对刻子或者是顺子,从第0层开始递归找刻子或者是顺子,当这张牌的张数大于等于3的时候,将这张牌的张数减去3,然后递归

2021-08-09 10:55:29 763

原创 Colored Cubes(彩色立方体)题解

彩色立方体(Colored Cubes)题解题意:有n个带颜色的立方体,每个面涂有一种颜色,要求重新涂尽量少的面,使的所有的立方体完全相同(两个立方体相同的含义是,存在一种旋转的方式,是的两个立方体对应面的颜色是相同的)思路首先定义一个数组p[i]表示编号i所在立方体中的位置,假设6个面的编号分别为1-6,其中位置和数字的对应关系如下,其实这就是一个标准的立方体的一个排列1 2 3 4 5 6前 右 上 下 左 后根据编号1,2,3,4,5

2021-08-07 16:41:56 485

原创 凸包的各种问题以及模板

一:求凸包的简洁板子1:求凸包#include <iostream>#include <algorithm>#include <iomanip>using namespace std;const int maxn = 50010;struct Point { int x, y; bool operator < (Point const& rhs) const {//重载为类的成员函数的时候,形参时运算符的右操作数

2021-07-27 16:28:11 199

原创 Codeforces Round #734 (Div. 3)题解

B2. Wonderful Coloring - 2题目的基本意思:1:每个元素要么不涂,要么只能涂一种颜色;2:每一种颜色涂的元素两两都是不相同的;3:每一种颜色涂的元素的个数时相同的;4:最后序列中涂的元素的个数要最大;解题的思路:1:去掉没必要涂的元素(1)该元素在序列中的个数要大于k(k表示颜色的总数),将超过k的那部分直接用0表示即可,不用涂;(2)为了保证每一种颜色涂的元素的个数时相同的,所以最后涂的元素的总个数一定是k的整数倍...

2021-07-24 12:25:29 190

原创 字典树总结(例题:在n个数中找出哪个数与输入的数异或和最大)

字典树的学习总结 这几天学习了字典树,字典树的大概意思就是给你一系列的字符串,在给你一些字符串,我们需要判断这些字符串是否是前面字符串的前缀。这种问题总共有两种操作,一个是插入字符串,一个是查询。查询的基本思路 从左到右遍历这个单词,若这个单词的字母没有出现在当前结点的子结点中,我们就将这个字母插入到当前结点的子结点中,如果已经出现了,我们就继续沿着当前结点的子节点继续往下面找。这里存在一个问题,我们要将这个字母查到那个地方,我们需要定义一个cnt的变量,当我们需要插入新的字母时,我们就++

2021-07-19 17:56:13 250

原创 用数组的方式来模拟链表

链表有两个重要的东西,一个是数据域,另一个是指针域。但是我们用结构体加指针的方式我们每次都要动态申请空间,而C++中的new函数实现非常的耗时,所以我们当有许多组数据的时候,我们通常采用数组模拟的方式来存储链表。 数组中的下标表示的是结点,e[N]表示的是当前结点里面存储的值,即数据域,ne[N]表示的是当前结点指向下一个节点的位置,即指针域。我们要实现还需要一个int类型的变量head,head表示头节点的下标,idx是一个指针,idx表示当前已经用到了哪个点(当我们在声明...

2021-07-10 23:33:20 190 3

原创 数据结构基础知识

基础数据结构 栈是一种后进先出的数据结构,而列是一种先进先出的数据结构,栈中有一个很重要的概念就是栈顶指针,当用数组实现栈的时候他就是int类型的变量,而用链表实现栈的时候他就是一个int*类型的指针。通常记为top,当栈中没有元素的时候令top=-1,当我们需要清空栈里面的元素的时候,我们直接可以用top=-1来实现。下面是栈的一些常用的操作1:获取栈中的元素int size(){ return top+1;//数组下标是从0开始,所以要加一}2:判断栈中是否还...

2021-07-06 16:38:31 176

JavaScript实现房屋平面图构建三维房屋空间

本系统是基于JavaScript实现房屋平面图构建三维房屋空间,是本人前端课程的课程设计。 本系统所包含的内容有: 1、3d房屋设计说明书。 2、系统运行代码,代码但是是在Hbuilder上面写的。

2022-10-14

C#基于asp.net的图书销售系统

1:本系统是基于asp.net开发的图书销售系统,开发的语言是C# 2:图书销售系统的功能有: 2.1 用户登录和注册 2.2 图书宣传 2.3 图书的增加删除修改查询 2.4 用户管理(用户信息查询,会员管理,普通用户管理,意见反馈) 2.5 后台管理(轮播图和推荐,销售情况查看,图书库存管理,图书录入等等) 3:压缩文件所包含内容: 3.1 系统开发文档 3.2 系统源码 3.3 数据库文件(sql脚本) 3.5 系统的所有材料 4:本系统可以作为期末课程设计的作业,也可以进行参考,系统为自己开发,当时用于自己的课程设计作业。 5:系统运行环境:Visual Studio,sqlserver即可运行。 6:本系统的界面非常的美观,逻辑非常的清晰,所有的逻辑和实现均在开发文档里面有说明,非常容易看懂。

2022-06-27

空空如也

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

TA关注的人

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