Noip 复习

news/2024/11/7 19:28:54/文章来源:https://www.cnblogs.com/YuenYouth/p/18524940

pbds

也叫做平板电视 Here,内含比 map 快很多的哈希表,甚至平衡树?!

封装了 hash、tree、trie、priority_queue 这四种数据结构

需要万能拓展库头文件 #include<bits/extc++.h>

以及 using namespace __gnu_pbds;

内带哈希表:如:gp_hash_table<int, int>cc_hash_table<int, int>

字符串算法

manacher

马拉车算法( ,OI-Wiki

算法介绍: 线性复杂度内找出以每个字符为回文中心的最长回文半径

存下模板代码(只用于求奇数回文):

int l = 0, r = -1;
for(int i=1; i<=n; i++){int k = i > r ? 1 : min(d[l+r-i], r-i+1);while(i - k > 0 and k + i <= n and s[i-k] == s[i+k]) k++;d[i] = k--;if(r < i + k) l = i - k , r = i + k;
}

偶数回文:直接把原字符串每相邻两个字符之间加上一个特殊字符就避免了偶数回文的情况,如 #

当时自己推的板子是个什么构思??

板子题: 【模板】manacher

code
#include<bits/stdc++.h>
#define Aqrfre(x, y) freopen(#x ".in", "r", stdin),freopen(#y ".out", "w", stdout)
#define mp make_pair
#define Type ll
#define qr(x) x=read()
typedef __int128 INT;
typedef long long ll;
using namespace std;inline ll read(){char c=getchar(); ll x=0, f=1;while(!isdigit(c)) (c=='-'?f=-1:f=1), c=getchar();while(isdigit(c)) x=(x<<1)+(x<<3)+(c^48), c=getchar();return x*f;
}const int N = 2.2e7 + 10; int n, d[N];
char in[N], s[N];signed main(){ // a// Aqrfre(a, a);cin>>(in+1); n = strlen(in+1);int cnt = 0;for(int i=1; i<=n; i++)s[++cnt] = '@', s[++cnt] = in[i];s[++cnt] = '@'; n = cnt;int l = 0, r = -1, ans = 0;for(int i=1; i<=n; i++){int k = i > r ? 1 : min(d[l+r-i], r-i+1);while(i - k > 0 and k + i <= n and s[i-k] == s[i+k]) k++;d[i] = k--;if(r < i + k) l = i - k , r = i + k;}for(int i=1; i<=n; i++){if(s[i] == '@') ans = max(ans, d[i] / 2 * 2); else ans = max(ans, d[i] - !(d[i] & 1));}cout<<ans<<"\n";return 0;
}

最小表示法

用于解决:有一个字符串,这个字符串的首尾是连在一起的,要求寻找一个位置,以该位置为起点的字符串的字典序在所有的字符串中中最小。

CSDN OI-Wiki

解释一下为什么 k==n 的时候 break,发现这种情况整个字符串是会存在循环节的,并且以循环节的每一个字符为开头都做过一遍了

模板代码:

int k = 0, i = 1, j = 2;
while(i <= n and j <= n){for(k=0; k<n; k++)if(in[i+k] != in[j+k]) break;if(k == n) break;if(in[i+k] < in[j+k]) j = max(j+k+1, i+1); //此时从 i~i+k 为开始的字符串都会小于相应的 j~j+k 位置开始的字符串,所以一定不以 j~j+k 为起点else i = max(i+k+1, j+1);
}i = min(i, j);

题:

Strange string

KMP

利用后缀函数线性求一个模板串在一个文本串里出现的次数或位置等等

CSDN

预处理出模板串的最大相等前后缀,与文本串进行匹配的时候每次匹配不上就将模板串的调到与此时后缀相同的前缀位置

预处理代码

inline void prefix(string s, int pi[]){ // pi[i]表示 s 到第 i 个字符时的串的前后缀的长度int len = s.length();for(int i=1; i<len; i++){int j = pi[i-1]; // j 表示到 i 前一个字符时的前缀最后一个字符的位置 + 1while(j and s[i] != s[j]) j = pi[j-1]; //j 继续往前跳到前缀最后一个字符 + 1 的位置if(s[i] == s[j]) ++j; //找到最大的 j 前后缀匹配上了,长度为位置 + 1pi[i] = j;}
}   

模板题

code
#include<bits/stdc++.h>
#define Aqrfre(x, y) freopen(#x ".in", "r", stdin),freopen(#y ".out", "w", stdout)
#define mp make_pair
#define Type int
#define qr(x) x=read()
typedef long long ll;
using namespace std;inline Type read(){char c=getchar(); Type x=0, f=1;while(!isdigit(c)) (c=='-'?f=-1:f=1), c=getchar();while(isdigit(c)) x=(x<<1)+(x<<3)+(c^48), c=getchar();return x*f;
}const int N = 1e6 + 5; string s, t;
int n, m, pre[N];inline void prefix(string s, int pi[]){ int len = s.length();for(int i=1; i<len; i++){int j = pi[i-1]; while(j and s[i] != s[j]) j = pi[j-1]; if(s[i] == s[j]) ++j;pi[i] = j;}
}   signed main(){ // a// Aqrfre(a, a);cin>>s>>t;n = s.length(), m = t.length();prefix(t, pre);for(int i=0,j=0; i<n; i++){while(j > 0 and s[i] != t[j]) j = pre[j-1];if(s[i] == t[j]) ++j;if(j == m){cout<<i-m+2<<"\n";j = pre[j-1];}}for(int i=0; i<m; i++) cout<<pre[i]<<" ";return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/828422.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

编写高质量代码(手撕代码)

首先上几个面试题:(真难)1. 手写函数实现数组扁平化(只减少一级嵌套)思路:function flatten(arr) {let res = [];arr.forEach((item) => {if (Array.isArray(item)) {item.forEach((e) => res.push(e));} else {res.push(item);}});return res;}console.log(flatte…

LeetCode LCR135[报数]

LeetCode LCR135[报数]题目 链接 LeetCode LCR135[报数] 详情实例题解 思路 通过 pow 函数对10进行幂运算,来获取报数范围 然后循环遍历 通过 push_back 方法将数字加入到容器内 代码 class Solution { public:vector<int> countNumbers(int cnt) {vector<int> iR…

语音 AI 迎来爆发期,也仍然隐藏着被低估的机会丨RTE2024 音频技术和 Voice AI 专场

在人工智能快速发展的今天,语音交互技术正经历一场革命性的变革。从语音识别到语音合成,再到端到端的语音对话系统,这一领域的创新正以前所未有的速度推进。这些进步不仅提升了技术指标,更为实时翻译、虚拟数字人、智能客服等实时互动场景带来了新的可能。本届 RTE2024 大会…

节能攻略,AUTOSAR PN局部网络管理技术!

随着整车功能的不断演进,车上各类用电设备(控制器、执行机构、感知设备等)的用电功耗越来越大,为了降低整车能耗,国内外很多OEM及Tire1都在考虑相关的机制及方案,其中PN局部网络管理机制,以其简单、灵活的特点获得众多落地应用。 随着整车功能的不断演进,车上各类…

AUTOSAR解决方案 — INTEWORK-EAS-CP

INTEWORK-EAS-CP(ECU AUTOSAR Software)是经纬恒润自主研发的符合AUTOSAR标准的软件产品。解决方案涵盖了嵌入式标准软件、AUTOSAR工具链、集成服务和培训等各个方面的内容,旨在为国内的OEM和供应商提供稳定可靠、便捷易用的AUTOSAR平台。 随着汽车电子技术的发展,汽…

多校A层冲刺NOIP2024模拟赛19

讲个笑话: (讨论时间) huge:(叹气)这讨论啊,就是改不了,这换了铃声了,也没…… 众人:现在是讨论时间啊。 huge:(停顿)那刚才大课间那会哇啦哇啦的…… 图书管理 简要题意 给定一个长度为\(n(n\le 10^4)\)的排列,求\(\sum\limits_{l=1}^n\sum\limits_{r=l}^n[r-l为…

hive基础知识分享(二)

继续学习hive的相关知识写在前面 今天继续学习hive部分的知识。 以下是您提供的内容转成的 Markdown 格式: Hive 相关知识 hive中不同的 count 区别select clazz,count(distinct id) as cnt,count(*) as cnt,count(1) as cnt_1,count(id) as cnt_id from students group by cl…

Mysql数据库一

CREATE DATABASE 数据库名;//创建数据库 SHOW databases;//查看数据库列表 USE 数据库名;//选择数据库 DROP DATABASE 数据库名://删除数据库

做好网站后如何让这个网站被更多的人浏览查看?

许多人都有这样一个问题:做好自己的网站,如何让这个网站被更多的人浏览看,查看到呢?有人可能会说简单粗暴的方式:买百度排名,买广告排名。没错,这是一直最直接的方式,但问题是这里的成本还是比较多的,对于之前没有做过SEM的个人和企业来说,在哪里买,买多少合适,买多…

http server

我下载了 https://archive.apache.org/dist/httpd/httpd-2.4.62.tar.gz 请问如何解压配置一个apache server,并配置新增端口30000,转发到nginx 32020端口 ⚠️由于网站限制,Kimi 未能阅读这个网页中的要解压、配置Apache服务器,并设置端口转发到Nginx,你可以按照以下步骤操作…

重链剖分学习笔记

一、引入 学习一个新的数据结构或者算法前,我们都要了解其用途,毕竟用途才是其被发明出来的原因。那么树链剖分有什么用呢?它维护的是什么样的信息呢?这里我们只探讨重链剖分。树链剖分用于将树分割成若干条链的形式,以维护树上路径的信息。 具体来说,将整棵树剖分为若干…