【学习笔记】AGC055
A - ABC Identity
如果只有AAA,BBB两种字符的话,我们发现要寻找p∈[1,n]p\in [1,n]p∈[1,n],使得[1:p][1:p][1:p]中AAA的数目与[p+1:n][p+1:n][p+1:n]中BBB的数目相同。
如果有A,B,CA,B,CA,B,C三种字符,我们可以先将A,BA,BA,B分离出来,再将B,CB,CB,C分离出来,最后把A,CA,CA,C分离出来,这样最后会生成888个子序列 然后无法通过
神谕告诉我们,A,B,CA,B,CA,B,C三种字符一共只有666种本质不同的排列,因此我们可以考虑把原序列分成长度为nnn的333段,从每一段中分别选取一个字符构成A,B,CA,B,CA,B,C的排列,最后把相同的排列放在一起即可。猜一下结论,这显然是有解的。
这种题还是要多尝试
#include<bits/stdc++.h>
#define pb push_back
using namespace std;
vector<int>v[3][3];
string s;
int n,res[600005];
int has(int x,int y,int z){return x*2+(y-(x<y))*1;
}
int main(){cin>>n>>s;for(int i=0;i<3*n;i++){v[i/n][s[i]-'A'].pb(i);}for(int i=1;i<=n;i++){for(int j=0;j<3;j++){for(int k=0;k<3;k++){for(int l=0;l<3;l++){if(v[0][j].size()&&v[1][k].size()&&v[2][l].size()&&j!=k&&k!=l&&j!=l){res[v[0][j].back()]=has(j,k,l);res[v[1][k].back()]=has(j,k,l);res[v[2][l].back()]=has(j,k,l);v[0][j].pop_back();v[1][k].pop_back();v[2][l].pop_back();}}}}}for(int i=0;i<3*n;i++)cout<<res[i]+1;
}
B - ABC Supremacy
如果只考虑SSS怎么生成TTT的话,怎么做都是O(n2)O(n^2)O(n2)的。数据删除
上面那种思路可能不太好处理 但是操作是可逆的,因此判断S,TS,TS,T同构的一个充分条件是它们都能到达一个相同的状态PPP。所以我们只要求出S,TS,TS,T的最小表示即可,这样一个字符串生成的表示是唯一的,就不用担心上述问题了。
剩下的就是怎么去寻找最小串。比较烦恼就先咕了
显然我们要凑出尽量多的ABCABCABC串(这里指轮换),并且每次操作相当于将ABCABCABC串这个整体挪到前面,然后把AAA放在最前面。那么BCBCBC是固定的吗?如果BCBCBC不是固定的,这个问题也比较烦恼,可以先咕着
开始慌张 不过幸运的是之前的结论还是正确的
我们可以把最小表示的定义换成 得到最多的ABCABCABC轮换组,那么BCBCBC就肯定是固定的了。
复杂度O(n)O(n)O(n)。
#include<bits/stdc++.h>
#define pb push_back
using namespace std;
int n;
string s,t;
vector<char>solve(string s){vector<char>v;for(int i=0;i<s.size();i++){v.pb(s[i]);if(v.size()>=3&&(v[v.size()-3]=='A'&&v[v.size()-2]=='B'&&v[v.size()-1]=='C'||v[v.size()-3]=='B'&&v[v.size()-2]=='C'&&v[v.size()-1]=='A'||v[v.size()-3]=='C'&&v[v.size()-2]=='A'&&v[v.size()-1]=='B')){v.pop_back();v.pop_back();v.pop_back();}}return v;
}
int main(){cin>>n>>s>>t;cout<<(solve(s)==solve(t)?"YES":"NO");
}
C - Weird LIS
如果我们能思考清楚{Ai}\{A_i\}{Ai}合法的充要条件,那么这道题也就解决了。
或者说能建立双射然后计数也行
想不太清楚所以先咕了
思路其实并不困难,不过可能需要猜几个结论。
1.11.11.1 如果AiA_iAi全部等于KKK,猜测K≤⌊n2⌋K\le \lfloor\frac{n}{2}\rfloorK≤⌊2n⌋,这还是比较容易看出来。
1.21.21.2 如果KKK和K−1K-1K−1同时存在,那么Ai=K−1A_i=K-1Ai=K−1的那些点是固定的,我们要在所有Ai=KA_i=KAi=K的连续段中挑选一段接在固定的数之间,那么根据1.11.11.1的推论,这一段的长度不能超过⌊l2⌋\lfloor\frac{l}{2}\rfloor⌊2l⌋(lll表示连续段长度),我们猜测对于更小的情况也是取得到的,因此∑⌊li2⌋+cntK−1≥K\sum{\lfloor\frac{l_i}{2}\rfloor}+cnt_{K-1}\ge K∑⌊2li⌋+cntK−1≥K,并且cntK−1≤Kcnt_{K-1}\le KcntK−1≤K。
这个向下取整好像不太妙,先咕了
计数这个地方可能要多尝试
复杂度O(n2)O(n^2)O(n2)。不过要注意特判Ai=n−1A_i=n-1Ai=n−1的情况。
#include<bits/stdc++.h>
#define ll long long
#define pb push_back
using namespace std;
const int N=5005;
int n,m,mod;
ll fac[N],inv[N],res;
ll pw(ll x,ll y=mod-2){ll z(1);for(;y;y>>=1){if(y&1)z=z*x%mod;x=x*x%mod;}return z;
}
void init(int n){fac[0]=1;for(int i=1;i<=n;i++)fac[i]=fac[i-1]*i%mod;inv[n]=pw(fac[n]);for(int i=n;i>=1;i--)inv[i-1]=inv[i]*i%mod;
}
ll binom(int x,int y){if(x<0||y<0||x<y)return 0;return fac[x]*inv[y]%mod*inv[x-y]%mod;
}
int main(){cin>>n>>m>>mod,init(n+1);for(int x=1;x<n;x++){for(int y=0;y<=(n-x)/2;y++){int L=max(3,x),R=min(m,x+y);if(L<=R)res=(res+binom(x+y,x)*binom(x+1,n-x-2*y)%mod*(R-L+1))%mod;}}for(int i=2;i<=min(m,n/2);i++)res++;if(m==n-1)res++;cout<<res%mod;
}
D - ABC Ultimatum
先考虑怎么判断给定串合法。
好像没什么思路先咕了
不过这题还是有学习的价值的,我们可以照着结论来翻译一下
设Sa(i),Sb(i),Sc(i)S_a(i),S_b(i),S_c(i)Sa(i),Sb(i),Sc(i)表示1∼i1\sim i1∼i中a,b,ca,b,ca,b,c的个数,Ma=max(Sb(i)−Sa(i)),Mb=max(Sc(i)−Sb(i)),Mc=max(Sa(i)−Sc(i))M_a=\max (S_b(i)-S_a(i)),M_b=\max(S_c(i)-S_b(i)),M_c=\max(S_a(i)-S_c(i))Ma=max(Sb(i)−Sa(i)),Mb=max(Sc(i)−Sb(i)),Mc=max(Sa(i)−Sc(i)),则SSS是好的当且仅当Ma+Mb+Mc≤nM_a+M_b+M_c\le nMa+Mb+Mc≤n
必要性应该很显然,可以猜一个结论,或者打表证明这是充要的。
可能有时间会补一下证明
然后暴力复杂度O(n7)O(n^7)O(n7)。但是很显然可以省去一维状态,因此就可以在O(n6)O(n^6)O(n6)时间内通过了。
#include<bits/stdc++.h>
#define ll long long
#define pb push_back
using namespace std;
const int mod=998244353;
int n,dp[17][17][17][17][17][17],res;
string s;
void add(int &x,int y){if((x+=y)>=mod)x-=mod;
}
int main(){cin>>n>>s;dp[0][0][0][0][0][0]=1;for(int i=0;i<3*n;i++){for(int a=0;a<=n;a++){for(int b=0;b<=n;b++){int c=i-a-b;if(c>n||c<0)continue;for(int j=0;j<=n;j++){for(int k=0;k<=n;k++){for(int l=0;l<=n;l++){int tmp=dp[a][b][c][j][k][l];if(s[i]=='A'||s[i]=='?'){add(dp[a+1][b][c][j][k][max(l,a+1-c)],tmp);}if(s[i]=='B'||s[i]=='?'){add(dp[a][b+1][c][max(b+1-a,j)][k][l],tmp);}if(s[i]=='C'||s[i]=='?'){add(dp[a][b][c+1][j][max(c+1-b,k)][l],tmp);}}}}}}}for(int i=0;i<=n;i++){for(int j=0;j<=n;j++){for(int k=0;k<=n;k++){if(i+j+k<=n)add(res,dp[n][n][n][i][j][k]);}}}cout<<res;
}
E - Set Merging
场上无一人AC
这种给你规定输入的构造题就很烦,那么我们就要去分析一些性质,看它在不同情况下是否成立。
某个人曾经说过,第一个做出这种题的人一定是具有非凡的人类智慧的
相关文章:
【学习笔记】AGC055
A - ABC Identity 如果只有AAA,BBB两种字符的话,我们发现要寻找p∈[1,n]p\in [1,n]p∈[1,n],使得[1:p][1:p][1:p]中AAA的数目与[p1:n][p1:n][p1:n]中BBB的数目相同。 如果有A,B,CA,B,CA,B,C三种字符,我们可以先将A,BA,BA,B分离出来…...
墨者——内部文件上传系统漏洞分析溯源 内部文件上传系统漏洞分析溯源
墨者——内部文件上传系统漏洞分析溯源 内部文件上传系统漏洞分析溯源 1.选择合适的文件上传 2.可以看到为*.asp文件 3.可以推测出此站点为IIS 4.上传shell.asp试试 5.上传报错,将其改名为shell.asp.txt上传,发现上传成功 6.有个问题就是服务器将我们所…...
5.2 Python if语句
5.2.3 检查是否不相等要判断两个值是否不等,可结合使用惊叹号和等号(!),其中的惊叹号表示不,在很多编程语言中都如此。下面再使用一条if语句来演示如何使用不等运算符。我们将把要求的比萨配料存储在一个变量中,再打印一条消息&am…...
ubuntu gerrit 配置
1 - 简介 参考地址: https://www.cnblogs.com/anliven/p/12019974.html https://www.cnblogs.com/anliven/p/11980432.html 虽然Gerrit 本身提供 Code Review和 Git 仓库的两大功能,但实际上很多项目用的是其他的Git仓库,例如GitLab和GitHub。 一般情况下,Gerrit位于最终…...
运动蓝牙耳机什么牌子好,运动蓝牙耳机品牌推荐
现在市面上运动耳机的品牌越来越多,还不知道选择哪一些运动耳机品牌,可以看看下面的一些耳机分享,运动耳机需要注意耳机的参数配置以及佩戴舒适度,根据自己最根本的使用需求来选择运动耳机。 1、南卡Runner Pro4骨传导蓝牙运动耳…...
(7)C#传智:方法及参数、重载(第7天)
一、方法作用域 被调用者需要调用者的值,方法有二: 1.传参数. private static void Main(string[] args){int m 3;Console.WriteLine(m);Console.ReadKey();}public static int GetMax(int m){return m 3;} 2.使用静态字段模拟全局. 多个方法都需要时&#x…...
Python 函数式编程
函数式编程:允许把函数本身作为参数传入另一个函数,还允许返回一个函数! 1.高阶函数 一个函数可以接收另一个函数作为参数,这种函数称之为高阶函数 abs(-10) 是函数调用 abs是函数本身 abs函数名其实是一个变量名 变量可以…...
pandas读取EXCEL列名重复问题解决——pandas设置多行为列名(多层列名)
问题呈现 这是我在问答区看到的一个问题。 问:在python中使用pandas读取Excel数据,重复数据被区分了,如何做到重复数据不被区分? 解决思路 很明显,这是pandas读取excel文件时列名设置问题,我第一时间想…...
CMake常用语法
1. cmake_minimum_required(VERSION 3.4.1) 指定需要的最小的cmake版本 2. aux_source_directory 查找源文件并保存到相应的变量中: #查找当前目录下所有源文件并保存至SRC_LIST变量中 aux_source_directory(. SRC_LIST)3. add_library 3.1 添加一个库 add_library(<n…...
Java知识复习(一)基础知识
1、什么是JVM、JDK和JRE? JVM是指运行Java字节码的虚拟机。而字节码文件指的就是扩展名为.class的文件,JDK指功能齐全的Java SDK,能够创建和编译程序JRE指Java运行的环境,包括JVM、类库和命令等 2、重载和重写的主要区别 重载&…...
springboot+vue.js校园车辆用车预约管理系统
springboot是基于spring的快速开发框架, 相比于原生的spring而言, 它通过大量的java config来避免了大量的xml文件, 只需要简单的生成器便能生成一个可以运行的javaweb项目, 是目前最火热的java开发框架 前端技术:nodejsvueelementui本项目的应用场景描述如下&…...
【 K8s 源码之调度学习】Pod 间亲和性和反亲和性的源码分析
查看案例 字段含义podAffinityPod 间的亲和性定义podAntiAffinityPod 间的反亲和性定义requiredDuringSchedulingIgnoredDuringExecution硬性要求,必须满足条件,保证分散部署的效果最好使用用此方式preferredDuringSchedulingIgnoredDuringExecution软性…...
计及绿证交易及碳排放的含智能楼宇微网优化调度(Matlab代码实现)
💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。 ⛳️座右铭&a…...
场景扩展,体验升级 | DBMotion新增无公网数据库迁移、支持监控报警等多项功能
丝滑的零停机数据库在线迁移工具——DBMotion,又双叒叕发新版:新增的网关、数据源功能,让你无公网IP的数据库也可以迁移;新增的监控功能,让你对迁移性能一目了然;新增的报警功能,让你及时获得同…...
【正点原子FPGA连载】第十五章eMMC读写测试实验 摘自【正点原子】DFZU2EG_4EV MPSoC之嵌入式Vitis开发指南
1)实验平台:正点原子MPSoC开发板 2)平台购买地址:https://detail.tmall.com/item.htm?id692450874670 3)全套实验源码手册视频下载地址: http://www.openedv.com/thread-340252-1-1.html 第十五章eMMC读写…...
i2c子系统
i2c 硬件协议 Linux 应用层读写i2c 数据 在Linux系统上,不仅可以在内核中使用 i2c 总线发送、接收数据,同时也支持应用层使用i2c 总线发送、接收。 如果在内核中使能了drivers/i2c/i2c-dev.c 配置,内核就会为每一个i2c 控制器生成一个/dev/…...
【K3s】第17篇 Helm版本和支持的Kubernetes版本对照表
目录 Helm版本和支持的Kubernetes版本对照表 Helm版本和支持的Kubernetes版本对照表 描述了在Helm和Kubernetes之间支持的最大版本偏差。 Helm的版本用 x.y.z 描述,x是主版本,y是次版本,z是补丁版本。 当一个Helm的新版本发布时࿰…...
如何自己搭建一个ai画图系统? 从0开始云服务器部署novelai
如何自己搭建一个ai画图系统? 从0开始云服务器部署novelai 上面两张图都是通过ai生成的,是不是有以假乱真的感觉。 本教程提供的是自己搭建一个可以外网访问的ai系统的方法,需要采购gpu服务器(后续会出白嫖的方式)&…...
SpringSecurity过滤请求导致的系统bug
背景 今天开发一个新的会员管理系统,继承了SpringSecurity的,用以控制权限。结果无论怎么配置,都会报错:An Authentication object was not found in the SecurityContext 这句话的意思很明确:指的就是在SecurityCon…...
css\js\vue知识点
1.css3新特性 css3新特性 1)选择器 2)阴影 3)形状转换(2D <-> 3D) 4)变形 5)动画(过渡动画、帧动画) 6)边框 7)多重背景 8)反…...
【Linux】shell脚本忽略错误继续执行
在 shell 脚本中,可以使用 set -e 命令来设置脚本在遇到错误时退出执行。如果你希望脚本忽略错误并继续执行,可以在脚本开头添加 set e 命令来取消该设置。 举例1 #!/bin/bash# 取消 set -e 的设置 set e# 执行命令,并忽略错误 rm somefile…...
.Net框架,除了EF还有很多很多......
文章目录 1. 引言2. Dapper2.1 概述与设计原理2.2 核心功能与代码示例基本查询多映射查询存储过程调用 2.3 性能优化原理2.4 适用场景 3. NHibernate3.1 概述与架构设计3.2 映射配置示例Fluent映射XML映射 3.3 查询示例HQL查询Criteria APILINQ提供程序 3.4 高级特性3.5 适用场…...
【快手拥抱开源】通过快手团队开源的 KwaiCoder-AutoThink-preview 解锁大语言模型的潜力
引言: 在人工智能快速发展的浪潮中,快手Kwaipilot团队推出的 KwaiCoder-AutoThink-preview 具有里程碑意义——这是首个公开的AutoThink大语言模型(LLM)。该模型代表着该领域的重大突破,通过独特方式融合思考与非思考…...
QT: `long long` 类型转换为 `QString` 2025.6.5
在 Qt 中,将 long long 类型转换为 QString 可以通过以下两种常用方法实现: 方法 1:使用 QString::number() 直接调用 QString 的静态方法 number(),将数值转换为字符串: long long value 1234567890123456789LL; …...
自然语言处理——循环神经网络
自然语言处理——循环神经网络 循环神经网络应用到基于机器学习的自然语言处理任务序列到类别同步的序列到序列模式异步的序列到序列模式 参数学习和长程依赖问题基于门控的循环神经网络门控循环单元(GRU)长短期记忆神经网络(LSTM)…...
OPENCV形态学基础之二腐蚀
一.腐蚀的原理 (图1) 数学表达式:dst(x,y) erode(src(x,y)) min(x,y)src(xx,yy) 腐蚀也是图像形态学的基本功能之一,腐蚀跟膨胀属于反向操作,膨胀是把图像图像变大,而腐蚀就是把图像变小。腐蚀后的图像变小变暗淡。 腐蚀…...
【电力电子】基于STM32F103C8T6单片机双极性SPWM逆变(硬件篇)
本项目是基于 STM32F103C8T6 微控制器的 SPWM(正弦脉宽调制)电源模块,能够生成可调频率和幅值的正弦波交流电源输出。该项目适用于逆变器、UPS电源、变频器等应用场景。 供电电源 输入电压采集 上图为本设计的电源电路,图中 D1 为二极管, 其目的是防止正负极电源反接, …...
云原生安全实战:API网关Kong的鉴权与限流详解
🔥「炎码工坊」技术弹药已装填! 点击关注 → 解锁工业级干货【工具实测|项目避坑|源码燃烧指南】 一、基础概念 1. API网关(API Gateway) API网关是微服务架构中的核心组件,负责统一管理所有API的流量入口。它像一座…...
【JVM】Java虚拟机(二)——垃圾回收
目录 一、如何判断对象可以回收 (一)引用计数法 (二)可达性分析算法 二、垃圾回收算法 (一)标记清除 (二)标记整理 (三)复制 (四ÿ…...
Python环境安装与虚拟环境配置详解
本文档旨在为Python开发者提供一站式的环境安装与虚拟环境配置指南,适用于Windows、macOS和Linux系统。无论你是初学者还是有经验的开发者,都能在此找到适合自己的环境搭建方法和常见问题的解决方案。 快速开始 一分钟快速安装与虚拟环境配置 # macOS/…...
