AtCoder Beginner Contest 215 (个人题解 A~F)
比赛链接:Here
AB水题,
C - One More aab aba baa
题意:
- 给出字符串 \(s\) 和整数 \(k\) ,请输出字典序第 \(k\) 大的原字符串 \(s\) 的排序
思路:
先说简单写法:
利用 C++ 内置函数
next_permutation直接排序即可(代码一)复杂写法:
枚举情况,设字符串长度为 \(n\) ,那么也就会有 \(2^n\) 种组合(先不管存在一样的),所以可以DFS来进行枚举爆搜(代码二)
int main() {
cin.tie(nullptr)->sync_with_stdio(false);
string s; int k;
cin >> s >> k;
sort(s.begin(), s.end());
while (k > 1) {
next_permutation(s.begin(), s.end());
k -= 1;
}
cout << s;
}
vector<string>vs;
string s, t;
int k, n;
void dfs(int x) {
if (x == 0) {
vs.push_back(t);
return ;
}
for (int i = 0; i < n; ++i) {
if (x & (1 << i)) { // 枚举第 i 位的情况
t.push_back(s[i]);
dfs(x ^ (1 << i));
t.pop_back();
}
}
}
int main() {
cin.tie(nullptr)->sync_with_stdio(false);
cin >> s >> k;
n = int(s.size());
dfs((1 << n) - 1);
sort(vs.begin(), vs.end());
unique(vs.begin(), vs.end());
cout << vs[k - 1];
}
D - Coprime 2
赛时很可惜这个没做出来QAQ
题意:
- 给定 \(n\) 个数字,请问在 \(1\sim M\) 中有多少个数字与给出的 \(n\) 个数字互质
思路:
- 首先像埃拉托色尼筛法一样先把 \([1,M]\) 的每个素数筛选出来,
- 然后把 \(a_i\) 的因子也统计出来(把其中的素数标记)
- 然后针对被标记的素因子从中删去即可
时间复杂度:\(\mathcal{O}(N\sqrt{\max{A}})\)
const int N = 1e5 + 10;
vector<int> pfact(int x) {
vector<int>ans;
for (int i = 2; i * i <= x; ++i) {
while (x % i == 0) {
x /= i;
ans.push_back(i);
}
}
if (x != 1) ans.push_back(x);
return ans;
}
int main() {
cin.tie(nullptr)->sync_with_stdio(false);
int n, m; cin >> n >> m;
vector<bool>st(N, true);
for (int i = 0, x; i < n; ++i) {
cin >> x;
vector<int> v = pfact(x);
for (auto &nx : v) {
if (st[nx]) for (int j = nx; j < N; j += nx) st[j] = false;
}
}
vector<int> ans;
for (int i = 1; i <= m; ++i) if (st[i]) ans.push_back(i);
cout << ans.size() << "\n";
for (int x : ans) cout << x << "\n";
}
E - Chain Contestant
题意:
我们有 \(10\) 种比赛类型:\(AAC, ..., AJC\) ,现在有 \(n\) 场比赛每场比赛以 \(AxC\) 表示,
RioTian 想要在 \(n\) 场比赛中选择并参加至少一项,并且满足以下条件
参加的比赛顺序中,同类型的比赛是连续的
形式上,参加的 \(x\) 场比赛并且其中的第 \(i\) 个比赛是 \(T_i\) 类型时,对于整数每个三元组 \((i,j,k)\) 使得 \(1\le i < j < k\le x,T_i = T_j\ if\ T_i =T_k\)
求出 \(RioTian\) 参加比赛的方式数 ,取模于 \(998244353\) 。
\]
考虑状压DP,
设 \(f[i][u][v]\) 表示为对于前 \(i\) 场比赛,迄今为止参加的比赛集以及最后参加比赛的种类为 \(v\) 时的方案数。
\(x\) 为第 \(i\) 场比赛的种类
- 对于每组 \(U\) 和每一种比赛 \(j\),在 \(f[i][u][j] += f[i - 1][u][j]\) (对应RioTian没有参加第 \(i\) 场比赛时),如果 $ j =x$ 也要加上 \(f[i - 1][u][j]\) (对应 RioTian 参加第 \(i\) 场比赛时与上一场参加的比赛类型相同)
- 对于每个不包含 \(x\) 的集合 \(V\) 和每种竞赛 \(j\) ,将 \(f[i-1][v][j]\) 添加到 \(f[i][v^‘][j]\) ,其中 \(v^‘\) 是添加了 \(x\) 的 \(v\) ,对应RioTian参加第 \(i\) 次比赛时和他上次参加的比赛不同
- \(f[i][w][x] += 1\) ,其中 \(W\) 代表仅包含 \(x\) 的集合(对应参加的第一场比赛是第 \(i\) 场比赛的情况)
最后输出 \(\sum f[n][u][j]\) (U为比赛集合,j 为比赛种类)
时间复杂度:\(\mathcal{O}(2^KNK)\)
const int mod = 998244353;
ll f[1024][1024][10];
int main() {
cin.tie(nullptr)->sync_with_stdio(false);
int n; string s;
cin >> n >> s;
for (int i = 1; i <= n; ++i) {
int x = s[i - 1] - 'A';
for (int u = 0; u < 1024; ++u)
for (int j = 0; j < 10; ++j) {
f[i][u][j] = f[i - 1][u][j];
if (j == x) {
f[i][u][j] += f[i - 1][u][j];
f[i][u][j] %= mod;
}
}
for (int v = 0; v < 1024; v++) {
if (v & (1 << x)) continue;
for (int j = 0; j < 10; j++) {
f[i][v | (1 << x)][x] += f[i - 1][v][j];
f[i][v | (1 << x)][x] %= mod;
}
}
f[i][(1 << x)][x]++;
f[i][(1 << x)][x] %= mod;
}
ll ans = 0;
for (int u = 0; u < 1024; ++u) for (int j = 0; j < 10; ++j)
(ans += f[n][u][j]) %= mod;
cout << ans;
}
F - Dist Max 2
F是一道思维题,
先贴一下代码
#include <bits/stdc++.h>
using namespace std;
int main() {
int n; cin >> n;
vector<pair<int, int>> v(n);
for (int i = 0; i < n; i++) cin >> v[i].first >> v[i].second;
sort(v.begin(), v.end());
int ok = 0, ng = 1000000001;
while (ng - ok > 1) {
int md = (ok + ng) / 2;
queue<pair<int, int>> que;
bool able = false;
int mi = 1000000001, ma = 0;
for (auto p : v) {
while (!que.empty()) {
if (que.front().first > p.first - md)break;
mi = min(mi, que.front().second); ma = max(ma, que.front().second);
que.pop();
}
if (mi <= p.second - md || ma >= p.second + md) able = true;
que.push(p);
}
if (able) ok = md;
else ng = md;
}
cout << ok << endl;
}
AtCoder Beginner Contest 215 (个人题解 A~F)的更多相关文章
- KYOCERA Programming Contest 2021(AtCoder Beginner Contest 200) 题解
KYOCERA Programming Contest 2021(AtCoder Beginner Contest 200) 题解 哦淦我已经菜到被ABC吊打了. A - Century 首先把当前年 ...
- AtCoder Beginner Contest 215 F题题解
F - Dist Max 2 什么时候我才能突破\(F\)题的大关... 算了,不说了,看题. 简化题意:给定\(n\)个点的坐标,定义没两个点的距离为\(min(|x_i-x_j|,|y_i-y_j ...
- 2018.09.08 AtCoder Beginner Contest 109简要题解
比赛传送门 水题大赛? 全是水题啊!!! T1 ABC333 就是判断是不是两个数都是奇数就行了. 代码: #include<bits/stdc++.h> using namespace ...
- AtCoder Beginner Contest 089完整题解
A - Grouping 2 Time limit : 2sec / Memory limit : 256MB Score : 100 points Problem Statement There a ...
- Atcoder Beginner Contest 138 简要题解
D - Ki 题意:给一棵有根树,节点1为根,有$Q$次操作,每次操作将一个节点及其子树的所有节点的权值加上一个值,问最后每个节点的权值. 思路:dfs序再差分一下就行了. #include < ...
- AtCoder Beginner Contest 238 A - F 题解
AtCoder Beginner Contest 238 \(A - F\) 题解 A - Exponential or Quadratic 题意 判断 \(2^n > n^2\)是否成立? S ...
- AtCoder Beginner Contest 137 F
AtCoder Beginner Contest 137 F 数论鬼题(虽然不算特别数论) 希望你在浏览这篇题解前已经知道了费马小定理 利用用费马小定理构造函数\(g(x)=(x-i)^{P-1}\) ...
- AtCoder Beginner Contest 154 题解
人生第一场 AtCoder,纪念一下 话说年后的 AtCoder 比赛怎么这么少啊(大雾 AtCoder Beginner Contest 154 题解 A - Remaining Balls We ...
- AtCoder Beginner Contest 153 题解
目录 AtCoder Beginner Contest 153 题解 A - Serval vs Monster 题意 做法 程序 B - Common Raccoon vs Monster 题意 做 ...
- AtCoder Beginner Contest 177 题解
AtCoder Beginner Contest 177 题解 目录 AtCoder Beginner Contest 177 题解 A - Don't be late B - Substring C ...
随机推荐
- 通过Spring MVC 实现 Restful 风格请求⽀持
通过Spring MVC可以很方便地实现Restful风格的请求支持.Restful风格的请求是一种基于HTTP协议的轻量级的Web服务架构风格,它通过HTTP的GET.POST.PUT.DELETE ...
- HTML5实战—canvas绘图之贝塞尔曲线
1.二次贝塞尔曲线 quadraticCurveTo(cpx,cpy,x,y) //cpx,cpy表示控制点的坐标, x,y表示终点坐标: 数学公式表示如下: 二次方贝兹曲线的路径由给定点P0.P1. ...
- 一文彻底看懂Python切片
1.什么是切片 切片是Python中一种用于操作序列类型(如列表.字符串和元组)的方法.它通过指定起始索引和结束索引来截取出序列的一部分,形成一个新的序列.切片是访问特定范围内的元素,就是一个Area ...
- 在路上---学习篇(一)Python 数据结构和算法 (2) -- 冒泡排序、选择排序、插入排序
独白: 第一次接触算法排序, 充满了好奇并且渴望了解其中原理,今天先学习了三种排序的方法,分别是 冒泡排序.选择排序.插入排序.学完以后发现数学知识真的很重要,越牛逼的算法要求知识越多,越精.虽说刚接 ...
- 自学day7 数组
typora-copy-images-to: media 数组 一.概念 对象中可以通过键值对存储多个数据,且数据的类型是没有限制的,所以通常会存储一个商品的信息或一个人的信息: var obj = ...
- CON2 工单重估 效率提升
CON2 工单重估 效率提升 业务背景:月结CON2 每次只能允许一个进程操作 集团公司较多的话,很影响月结效率. SAP提供了专家模式程序 RKAZCON2 ,可以选平行运行 平行处理 需要选服 ...
- .NET Conf 2023 Chengdu - 成都站圆满结束!
今年的.NET Conf 2023,中国区首次有两个会场举办Local Event,成都会场已于上周六12月9日圆满结束. 本次成都会场共计100+余名.NET开发者报名参与,共计10+名志愿者参与筹 ...
- C++ Qt开发:DateTime日期时间组件
Qt 是一个跨平台C++图形界面开发库,利用Qt可以快速开发跨平台窗体应用程序,在Qt中我们可以通过拖拽的方式将不同组件放到指定的位置,实现图形化开发极大的方便了开发效率,本章将重点介绍QDateTi ...
- 时间加权平均价格算法(TWAP)和成交量平均算法(VWAP)在量化回测的应用
为什么要引入TWAP和 VWAP? 为了评估策略的资金容量,我们对M.trade模块里买入点和卖出点这两个参数进行了更丰富的扩展,支持了策略能够按更丰富的算法交易价格(WAP)进行撮合. 如果资金是1 ...
- Linux应急响应总结——更新中
Linux应急响应 用户信息 方向 查看可登录的用户: cat /etc/passwd | grep /bin/bash awk -F: '{if($7!="/usr/sbin/nologi ...