AtCoder Beginner Contest 242(C~E)
AB 水题
C - 1111gal password
题意:给出 N(\(2\le N\le 1e6\))求满足以下条件的 \(X\) 的数量,需除以模 (\(998244353\))
- $X $ 是 \(N\) 位数
- 对于 \(X_1,X_2,...,X_N\) 的每位数
- \(1\le X_i \le 9\)
- \(|X_i - X_{i+1}| \le 1\)
思路:
emm,直接看过去知道是比较明显的数论推导问题,随便写了几组发现当定义状态 \(f_{i,j}\) 表示长度为 \(i\) 符合条件的数字,结尾数位是 \(j\) 有多少个。递推式如下:
f_{i, j}=f_{i-1, j-1}+f_{i-1, j}+f_{i-1, j+1} \\
f_{i, 0}=f_{i, 10}=0 \\
f_{1, j}=1
\end{array}
\]
【AC Code】
const int N = 1e6 + 10, mod = 998244353;
ll n;
ll f[N][11];
int main() {
ios::sync_with_stdio(false), cin.tie(nullptr);
cout << fixed << setprecision(20);
cin >> n;
for (int i = 1; i <= 9; i += 1) f[1][i] = 1;
for (int j = 2; j <= n; j++)
for (int i = 1; i <= 9; i++)
f[j][i] = (f[j - 1][i - 1] + f[j - 1][i] + f[j - 1][i + 1]) % mod;
// 定义初始和结尾以及初始值
// {1,2,3,4,5}, accumulate(a[0], a[5],0ll) = 15
cout << accumulate(f[n] + 1, f[n] + 10, 0ll) % mod;
}
D - ABC Transform
题意:
给定一个长度为 \(N\) 的字符串 \(S\) ,由A B C 三种字符组成,每一次变化会使 \(S\) 中的 A 全部变成 BC ,B 全部变成 CA ,C 全部变成 AB ,如 ABC 在一次变化后会变成 BCCAAB 。现在有 Q 个询问,每个询问都是求原串 \(S\) 经过 \(t_i\) 次变化后第 \(k_i\) 个字符
分析:
首先可以看出一个字符执行了 \(t\) 次操作以后的长度是好计算的,所以我们先把问题变成一个字符执行 \(t\) 次操作之后的第 \(k\) 个是什么。
上面的东西可以考虑作为递归做,即定义函数类似 \(f(c,t,k)\) 表示字符 \(c\) 执行了 \(t\) 次操作得到的字符串第 \(k\) 个是什么,只是存在一个问题:\(t(\le 1e18)\) 太大了
观察到每次操作会把字符串长度加倍,所以执行很少操作后,就变成了对 \(f(c,t,1)\) 求值。然而操作三次以后第一个字符等价于没有改变,所以可以直接得到结果。
Update:发现原思路虽然正确但有点绕
令 $f(t,k) $ 为原 \(S\) 经过 \(t_i\) 次变化后得到的 \(k_i\) 字符
首先,当 \(t=0\) 时,直接输出 \(S_k\) 即可
其次,当 \(t \not= 0\) ,我们需要知道 \(f(t,k)\) 从何而来
样例
ABC ->
BCCAAB ->
CAABABBCBCCA
采用分类讨论的方法,不难发现
- 当 $ k\in {2m+1 | m\in Z}$ (即 \(k\) 为奇数时),\(f(t - 1, \frac{k + 1}2) \to f(t,k)\)
- 当 $ k\in {2m | m\in Z}$ (即 \(k\) 为偶数时),\(f(t - 1, \frac{k}2) \to f(t,k)\)
怎么进行变化?
可以概阔为一个 \(g\) 函数:
inline char g(char ch, int x) { return (ch - 'A' + x) % 3 + 'A';}
但是,如果我们每一次都去递归 \(t\) 还是太大了,直接炸了。那么只能动 \(k\) 了
观察样例中字符串首,它们是 A B C 轮换的。
利用这条性质,当 \(k=0\) 即可直接求 \(f(t,0) = g(S.front(),t mod 3)\)
但是问题来了,这样一个算法肯定会对 \(k\) 取模,万一 \(k = 0...\)
所以,我们把 \(S\) 的改为编号 \(0 \to N-1\)
此时:
- 当 $ k\in {2m+1 | m\in Z}$ (即 \(k\) 为奇数时),\(f(t - 1, \frac{k - 1}2) \to f(t,k)\)
- 当 $ k\in {2m | m\in Z}$ (即 \(k\) 为偶数时),\(f(t - 1, \frac{k}2) \to f(t,k)\)
代码就很好写了
string s;
ll q, t, k;
inline char g(char ch, int x) { return (ch - 'A' + x) % 3 + 'A';}
char f(ll t, ll k) {
if (!t) return s[k];
if (!k) return g(s[0], t % 3);
return g(f(t - 1, k >> 1), (k & 1) + 1);
}
int main() {
ios::sync_with_stdio(false), cin.tie(nullptr);
cout << fixed << setprecision(20);
cin >> s >> q;
while (q --) {
cin >> t >> k;
cout << f(t, k - 1) << "\n";
}
}
E - (∀x∀)
title 好玩
我们可以枚举两个字符串相同的前缀有多长,然后在后一个位置给串 \(X\) 填更小的字符,再之后的位置可以随便填了。
- 需要判断 \(X\) 的前半段全部和 \(S\) 相同时,后半段是否小于等于 \(S\)。
const int N = 1e6, mod = 998244353;
ll pw[N + 10] = {1};
string s;
int T, n;
int main() {
ios::sync_with_stdio(false), cin.tie(nullptr);
cout << fixed << setprecision(20);
for (int i = 1; i <= N; i += 1) pw[i] = pw[i - 1] * 26ll % mod;
cin >> T;
while (T--) {
cin >> n >> s;
s = "@" + s;
int ans = 0;
bool f = 1;
for (int i = 1; i <= (n + 1) / 2; i++) {
int a = s[i] - 'A', b = s[n + 1 - i] - 'A';
ans = (ans + (ll)a * pw[(n + 1) / 2 - i]) % mod;
f &= a <= b;
f |= a < b;
}
cout << (ans + f) % mod << "\n";
}
}
AtCoder Beginner Contest 242(C~E)的更多相关文章
- Atcoder Beginner Contest 147C(状态压缩)
最多15个人,用N个二进制的数字表示每个人的状态,然后检验.这串数字相当于已经把这些人的状态定了下来,如果和输入的情况不符则这串数字不正确,直接忽略,因为枚举了所有的情况,所以总有正确的,不必在错误的 ...
- AtCoder Beginner Contest 254(D-E)
Tasks - AtCoder Beginner Contest 254 D - Together Square 题意: 给定一个N,找出所有不超过N的 ( i , j ),使得( i * j )是一 ...
- AtCoder Beginner Contest 086 (ABCD)
A - Product 题目链接:https://abc086.contest.atcoder.jp/tasks/abc086_a Time limit : 2sec / Memory limit : ...
- AtCoder Beginner Contest 085(ABCD)
A - Already 2018 题目链接:https://abc085.contest.atcoder.jp/tasks/abc085_a Time limit : 2sec / Memory li ...
- AtCoder Beginner Contest 084(AB)
A - New Year 题目链接:https://abc084.contest.atcoder.jp/tasks/abc084_a Time limit : 2sec / Memory limit ...
- AtCoder Beginner Contest 083 (AB)
A - Libra 题目链接:https://abc083.contest.atcoder.jp/tasks/abc083_a Time limit : 2sec / Memory limit : 2 ...
- AtCoder Beginner Contest 264(D-E)
D - "redocta".swap(i,i+1) 题意: 给一个字符串,每次交换相邻两个字符,问最少多少次变成"atcoder" 题解: 从左到右依次模拟 # ...
- Atcoder Beginner Contest 121D(异或公式)
#include<bits/stdc++.h>using namespace std;int main(){ long long a,b; cin>>a>&g ...
- Atcoder Beginner Contest 156E(隔板法,组合数学)
#define HAVE_STRUCT_TIMESPEC #include<bits/stdc++.h> using namespace std; ; ; long long fac[N] ...
- Atcoder Beginner Contest 155E(DP)
#definde HAVE_STRUCT_TIMESPEC #include<bits/stdc++.h> using namespace std; ]; int main(){ ios: ...
随机推荐
- C语言输入任意长度数组后,再在该数组中查找特定的值,并且可查找多个相同的值
C语言输入任意长度数组后,再在该数组中查找特定的值,并且可查找多个相同的值 例:在a[20] = { 99,42,57,74,46,85,32,78,40,33,74,88,65,27,38,69,5 ...
- Kubernetes 漫游:etcd
概述 etcd 是一个基于 Raft 协议实现.开源的.分布式的键值存储系统.主要用于在分布式系统中提供强一致性和高可用性的数据存储. etcd 在 Kubernetes 中的作用如下: 集群状态数据 ...
- 机密计算如何引领AI开发的安全未来
机密计算如何引领AI开发的安全未来 PrimiHub一款由密码学专家团队打造的开源隐私计算平台,专注于分享数据安全.密码学.联邦学习.同态加密等隐私计算领域的技术和内容. 先进的AI模型比如机器学习和 ...
- 提升效率,打通万里牛ERP与下游用友U8财务软件的无缝对接
一.对接流程 1.1 销售/售后流程 在万里牛订单出库后,通过轻易云数据集成平台将数据推送至用友U8销售订单和销售出库单,这些单据可以进行关联操作. 当万里牛售后单完成退货入库后,通过数据集成平台将数 ...
- 【Javaweb】六-servlet层
AdminServlet.jap @WebServlet("/AdminServlet") public class AdminServlet extends HttpServle ...
- StackGres 数据库平台工程,使用 Citus + Patroni 创建生产级高可用分布式 PostgreSQL 分片集群
系列 StackGres, 可私有部署的云原生数据库平台工程 StackGres 数据库平台工程功能介绍与快速上手 StackGres 1.6 数据库平台工程集群配置管理(K8S Pods/Postg ...
- JPA动态注册多数据源
背景 目前已经是微服务的天下,但是随着业务需求的日益增长,部分应用还是出现了需要同时连接多个数据源操作数据的技术诉求. 需要对现有的技术架构进行优化升级,查阅了下网上的文章,基本都是照搬的同一篇文章, ...
- H5自适应
一.设置html的font-size,使用rem作为单位 假设设计稿宽度750px,屏幕宽高750px, 1.1rem=屏幕宽度/设计稿宽度*100px,适合用px表示宽度 1rem=100px re ...
- URL路径参数转换器
作用和基本使用 作用: 用于校验请求的路由参数中的值是否符合符合指定的规则. 这个使用方法和django中的路由参数转换器是差不多的. 至于为什么用路径参数转换器,原因和django中的一样,虽然你可 ...
- 华企盾DSC:wps个人模式无策略组新建的文件仍然加密
解决方法:右键wps安装目录手动解密即可(原因:wps模板被加密导致)