自定义博客皮肤VIP专享

*博客头图:

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

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

博客底图:

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

栏目图:

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

主标题颜色:

RGB颜色,例如:#AFAFAF

Hover:

RGB颜色,例如:#AFAFAF

副标题颜色:

RGB颜色,例如:#AFAFAF

自定义博客皮肤

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

原创 树链剖分

例题:「一本通 4.5 例 1」树的统计 // from:https://oi-wiki.org/graph/hld/ #include <algorithm> #include <cstdio> #include <cstring> #define lc o << 1 #define rc o << 1 | 1 const int maxn = 60010; const int inf = 2e9; int

2022-04-11 22:45:04 334

原创 排序算法

快速排序选定第一个元素x为中心轴 将小于x的数字放在x的左边 将大于x的数字放在x的右边 分别对左右子数组重复前3步操作代码:#include <bits/stdc++.h>using namespace std;void quick_sort(vector<int>& a, int l, int r) { if (l >= r) return; int mid = a[l], left = l, right = r; wh

2022-03-06 16:06:58 452

原创 Python拼音库pypinyin

安装cmd下输入:pip install pypinyin效果:>>> import pypinyin>>> print(pypinyin.pinyin('哈喽'))[['hā'], ['lóu']]>>> print(pypinyin.lazy_pinyin('哈喽'))['ha', 'lou']

2022-03-01 02:41:27 914

原创 网络流

想看定义和证明可以到算法学习笔记(28): 网络流 - 知乎最大流EK算法1.残留网络的可行流+原图的可行流=原题的另一个可行流2.可行流的残留网络中不存在增广路,那么就找到了最大流// 例题https://www.acwing.com/problem/content/description/2173/// EK算法时间复杂度为O(点数*边数^2),但是这个复杂度非常玄学,上界非常宽松// 基本可以解决点数+边数<10000的问题#include <bits/s.

2022-02-25 21:17:24 376

原创 最小生成树

用n - 1条边将n个点连起来,当n - 1条边的权值之和最小,形成的树就是最小生成树如这张图:的最小生成树为4条边将5个点连起来,权值之和为7问题:给你一个n个点的带权无向连通图,节点编号为0到n - 1,同时还有一个数组edges,其中edges[i] = [from,to,weight] 表示在from和to节点之间有一条权值为weight的无向边,求这个图的最小生成树的权值和下面用kruskal算法解决该问题:步骤:1、cnt记录当前生成树中的边数,res记录权值之和..

2022-02-15 19:53:53 175

原创 匈牙利算法

先来看这么一个问题:一个班级里有n个男生和m个女生,我们有一个n × m的矩阵,grid[i][j] = 1表示第i个男生和第j个女生相互喜欢,问这个班最多能凑出几对情侣(情侣定义:一男一女)标准的二分图最大匹配问题,只可意会不可言传,具体看代码class Solution: def maximumInvitations(self, grid: List[List[int]]) -> int: n = len(grid) m = len(grid[.

2022-02-14 20:37:54 252

原创 树的直径

leetcode1245. 树的直径给你这棵「无向树」,请你测算并返回它的「直径」:这棵树上最长简单路径的边数。我们用一个由所有「边」组成的数组 edges来表示一棵无向树,其中edges[i] = [u, v]表示节点u 和 v之间的双向边。树上的节点都已经用{0, 1, ..., edges.length}中的数做了标记,每个节点上的标记都是独一无二的。0 <= edges.length <10^4 edges[i][0] != edges[i][1]...

2022-02-08 15:32:43 83

原创 ST表

背景:给定n个数,有m个询问,对于每个询问,你需要回答区间[l, r]中的最大值,ST表基于倍增的思想,可用做到O(nlogn)预处理,O(1)回答每个询问,但是不支持修改操作ST表板子题#include <bits/stdc++.h>using namespace std;int a[100005], st[100005][20], n, m;void init() { int k = __lg(n); for(int i = 1; i &lt..

2022-02-05 17:49:43 399

原创 bisect

Python自带的一个二分库,列表有序时使用导入import bisect找到第一个大于等于x的数的位置>>> a = [1, 2, 2, 2, 3]>>> pos = bisect.bisect_left(a, 2)>>> pos1>>> a[pos]2找到第一个大于x的数的位置>>> a = [1, 2, 2, 2, 3]>>> pos = bisec

2022-02-01 18:19:38 573

原创 DFS序

DFS序:每个节点在DFS深度优先遍历中的进出栈的时间序列树是一种非线性结构,所以对树进行区间操作会很不方便,所以要考虑将树转化成数组形式以便操作对树进行一趟DFS,同时维护一个时间戳,记录每个结点被访问的时间,可以想象,对同一棵子树上的结点,访问的时间一定是相连的,映射到数组上就是一片连续的区间,如此,对一棵子树进行操作,可以等价于对一片连续的区间进行操作,区间操作常常可以使用树状数组或线段树维护我们常常需要维护以下信息:Time:时间戳l[i]:dfs进入子树i的时间r[i]:.

2021-12-03 13:06:51 960 1

原创 Python3的各种排序方法

升序排序:>>> d = [3, 2, 4, 1]>>> d.sort()>>> d[1, 2, 3, 4]降序排序:>>> d = [3, 2, 4, 1]>>> d.sort(reverse = True)>>> d[4, 3, 2, 1]自定义排序:按个位数大小排序>>> d = [11, 0, 28, 123, 9]>&...

2021-12-02 00:02:06 4788

原创 Python3记录程序运行时间

import timestarttime = time.time() # 开始记录# time.sleep(1) 延时1s# 跑程序for i in range(100000000): passendtime = time.time() # 结束记录dtime = endtime - starttimeprint("程序运行时间:%.8s s" % dtime) # 显示到微秒...

2021-11-30 20:30:30 862

原创 Python3将数据写入txt文件

f = open('1.txt', 'w')for i in range(100): f.write("Nreyong\n")f.close()如果当前目录中没有发现1.txt,则程序将先创建一个名为1.txt的文件,再将结果写入

2021-11-30 19:39:27 2013

原创 求组合数

方法一:由组合数公式进行递推其实就是求出杨辉三角11 11 2 11 3 3 11 4 6 4 11 5 10 10 5 11 6 15 20 15 6 1...这个两重循环就能求,当枚举的是每一行的最左边元素,就c[i][0] = 1否则c[i][j] = c[i - 1][j] + c[i - 1][j - 1]#include <bits/stdc++.h>using namespace std;int c[5005][5005], ...

2021-11-27 00:32:18 258

原创 分块算法

通常把长度为n的数列分成块在进行区间操作前通常需要预处理以下数据:数组l,l[i]表示第i块的最左边元素的位置 数组r,r[i]表示第i块的最右边元素的位置 数组pos,pos[i]表示第i个元素在第几个块内注:若是有多余元素,则多余元素算入最后一个块内,如:有10个元素,则块数为下取整,也就是3个块,此时分块情况为{1,2,3},{4,5,6},{7,8,9,10}分块算法的精髓在于,对于一次区间操作,对区间內部的整块进行整体的操作,对区间边缘的零散块单独暴力处理在对区间[left.

2021-11-09 19:35:33 946

原创 线性基

可以解决与异或有关的题目思路:在一个较大的集合中(假设有1e5个数),有一些数是没用意义的,因为它可以由其它数异或得到,我们若是能消除这些没有意义的数,得到一个较小的集合(60个数左右),使得对这个较小的集合进行操作,等价于对大集合进行操作,显然可以极大的提升时间复杂度。对于任意一个集合,如果其中有两个元素的最高位都是1,可以用异或将其中一个元素替换掉,如此往复,可以让集合用某一位作为最高位的数唯一,这样我们就可以用60个数的集合,来表示1e5个数的集合。被替换掉的数显然可以通过集合元素异或得.

2021-10-27 21:42:59 3736

原创 KMP算法

一种十分优秀的字符串匹配算法,时间复杂度为线性首先定义如下变量:a - 文本串b - 模式串现求b串在a串中出现的次数我们又定义如下变量:i - 指向文本串a的指针j - 指向文本串b的指针nxt - nxt[j]表示串b[0:j]中既是前缀也是后缀(不包括b[0:j]自身)的字符串的最大长度res - 记录串b在串a中出现的次数在a[i] != b[j]时,当前位置发生匹配失败,此时我们应该想到回退j,使得b[0: j]这样的最长前缀能够匹配到a[i - j..

2021-10-13 19:12:06 87

原创 multiset

#include <bits/stdc++.h>using namespace std;struct cmp { bool operator() (int a, int b) { return a > b; }};int main() { // 1、初始化 multiset<int> s1; multiset<int, cmp> s2; // 自定义排序 // 2、添加元素 for.

2021-10-10 20:20:56 218

原创 random

导入:import random1、random.random():返回一个随机数,其在0至1的范围之内>>> random.random()0.78128306826774722、random.uniform():在指定范围内生成随机数,其有两个参数,一个是范围上限,一个是范围下线>>> random.uniform(2, 6)5.08082934777763、random.randint():随机生成指定范围内的整数,其有两个参数,.

2021-10-09 13:27:08 114

原创 快读、快写

只能读整型#include <bits/stdc++.h>using namespace std;template <typename T> void inline read(T &x) { int f = 1; x = 0; char s = getchar(); while (s < '0' || s > '9') { if (s == '-') f = -1; s = getchar(); } while (s <=

2021-10-08 20:23:28 147

原创 可持久化线段树

可持久化线段树的意思就是可以查询和修改历史版本线段树具体实现:我们采用动态开点的方式来建立线段树 build和query操作与普通动态开点线段树如出一辙 对于修改操作,我们新增修改后的结点及其父结点,未修改过的结点直接copy过来 对于一次修改,就是一次新增祖宗的过程,也是一次添加新版本的过程各变量含义:t[i]- i所表示区间的权值lson[p] - p结点左儿子所在位置rson[p] - p结点右儿子所在位置v[i] - 版本i起始结点所在位置cnt - ...

2021-10-07 16:50:38 234

原创 质数的筛法

埃氏筛:用质数把质数的倍数筛掉#include <bits/stdc++.h>using namespace std;bool prime[1000005];int main() { int n; cin >> n; memset(prime, 1, sizeof prime); for (int i = 2; i <= n; i++) { if (prime[i]) { for (int j

2021-10-05 13:10:43 144

原创 高斯消元解方程

题目链接:P3389 高斯消元法算法原理:两方程互换,解不变 一方程乘以非零数k,解不变 一方程乘以数k加上另一方程,解不变代码:#include <bits/stdc++.h>using namespace std;double a[105][105];int main() { int n; cin >> n; for (int i = 0; i < n; i++) { for (int j = 0;..

2021-10-04 14:07:55 183

原创 最短路算法

dijkstra:119.单源最短路#include <bits/stdc++.h>using namespace std;typedef long long ll;ll n, m, s, t;ll g[3000][3000];bool r[3000];int main() { cin >> n >> m >> s >> t; for (int i = 0; i <= n; i++) { fo

2021-10-01 18:15:02 148

原创 关于除法取模

(a / b) % mod = a * pow(b, mod - 2, mod) % mod>>> mod = 10 ** 9 + 7>>> a = 20000000000>>> b = 2>>> (a // b) % mod999999937>>> a * pow(b, mod - 2, mod) % mod999999937将除法操作转化为乘法可以避免误差...

2021-09-29 12:38:54 153

原创 动态开点线段树

适用场景:需要开一棵空间非常大的线段树 数组下标需要以负数为索引具体实现:我们是一边修改一边动态建立线段树,所以不需要build 获取左右儿子不再是p * 2 和 p * 2 + 1,而是用两个数组 lson[p] 和 rson[p] 存两个儿子所在位置 与lazy标记有同样的思想,需要访问儿子时,再动态地为它分配位置,所以大多数儿子都是以虚拟的方式存在,这样就避免了空间浪费优点:解决了空间限制的问题 无视索引下标的限制,用一个数组元素表示一段区间的值。例如,求数组下标 -100.

2021-09-28 20:20:28 384

原创 一个数列找规律网站

http://oeis.org/组合数学,动态规划找规律必备

2021-09-27 18:01:30 857

原创 二进制枚举

C++:#include <bits/stdc++.h>using namespace std;int main() { int n; cin >> n; for (int i = 0; i < (1 << n); i++) { cout << i << "的子集有:"; for (int j = i; j; j = (j - 1) & i) {

2021-09-21 18:21:33 161

原创 collections

导入import collections1、计数器Counterc = collections.Counter('nreyong')print(c.items()) #打印键、值print(c.keys()) #打印键print(c.values()) #打印值print(c.pop('a')) #删除键'a'并将值带回c.clear() #清空cd = collections.Counter('Python')c.update(d) #将d中的值加到c上c.

2021-09-20 17:38:40 95

原创 heapq

1、导入库import heapq2、初始化法一:nums = [1, 3, 2, 5]q = []for i in nums: heapq.heappush(q, i)法二:q = nums[:]heapq.heapify(q)3、依次输出堆顶元素while q: print(heapq.heappop(q))4、访问堆顶元素并替换之heapq.heapreplace(q, x)5、获取最大n个/最小n个元素maxn = heapq.n

2021-09-19 21:14:59 281

原创 树状数组

单点修改,区间查询int t[1000005], n, m;void add(int x, int v) { for (; x <= n; x += x & -x) { t[x] += v; }}int ask(int x) { int res = 0; for (; x > 0; x -= x & -x) { res += t[x]; } return res;}区间修改,区间查询

2021-09-19 16:11:30 188

原创 字符串哈希

1、字符串匹配:实现 strStr() (当KMP用,不会KMP的菜鸡留下了泪水)typedef unsigned long long ull;ull p[100000], pre[100000];class Solution {public: ull get(int l, int r) { return pre[r] - pre[l - 1] * p[r - l + 1]; } int strStr(string s, string needle)..

2021-09-17 13:31:00 96

原创 快速幂

C++:#include <bits/stdc++.h>using namespace std;const int MOD = 1e9 + 7;int pow(int a, int b) { int res = 1; while (b) { if (b & 1) { res = (long long)res * a % MOD; } a = (long long)a * a % MOD;

2021-09-17 13:20:54 111

原创 模拟退火随机大法

如:求最小权值各变量含义T:当前温度 T_min:熄火时刻 r:退火速度 delta:距离差 now:当前状态 next:随机选的状态 calc(now):当前状态权值 res:当前最优解 cnt:执行模拟退火次数import randomimport mathn = int(input())now = list(range(0, n)) # 初始化状态res = float('inf')cnt = 50def calc(st): res = 0

2021-09-16 23:03:30 138

原创 前缀树

题目链接:实现Trie(前缀树)请你实现 Trie 类:Trie() 初始化前缀树对象。void insert(String word) 向前缀树中插入字符串 word 。boolean search(String word) 如果字符串 word 在前缀树中,返回 true(即,在检索之前已经插入);否则,返回 false 。boolean startsWith(String prefix) 如果之前已经插入的字符串word 的前缀之一为 prefix ,返回 true ;否则,返回 fa.

2021-09-16 22:55:42 157

原创 线段树(区间修改,区间查询)

题目链接:区间修改,区间查询build,基于后序遍历和区间二分的思想,递归建树 change,1、r<s||l>t,当前区间与待修改区间没有交集,直接return 2、s<=l&&r<=t,当前区间为待修改区间的子区间,更新区间权值和懒标记 3、当前区间与待修改区间有部分交集,则将懒标记下传,并递归查找子区间,同时维护线段树 query:1、r<s||l>t,当前区间与查询区间没有交集,返回0 2、s&l...

2021-09-16 18:09:26 677

原创 线段树(单点修改,区间查询)

题目链接:单点修改,区间查询build:基于后序遍历和区间二分的思想,递归建树 change:1、r<x||l>x,当前区间与要修改的点无交集,直接return掉 2、l==r&&l==x,这个点为要修改的点,把对应位置修改后return 3、其他情况,递归找要修改的点,同时维护修改后的树 query:1、r<s||l>t,当前区间与查询区间无交集,返回0 2、s<=l&&r<=...

2021-09-16 17:45:28 323

空空如也

空空如也

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

TA关注的人

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