CodeTON Round 3 (Div. 1 + Div. 2, Rated, Prizes!) A-D
A
题解
知识点:贪心。
注意到 \(a[1] \neq 1\) , \(1\) 永远不可能换到前面;\(a[1] = 1\) 可以交换后面任意元素。
时间复杂度 \(O(n)\)
空间复杂度 \(O(n)\)
代码
#include <bits/stdc++.h>
#define ll long long
using namespace std;
int a[20];
bool solve() {
int n;
cin >> n;
for (int i = 1;i <= n;i++) cin >> a[i];
if (a[1] == 1) cout << "YES" << '\n';
else cout << "NO" << '\n';
return true;
}
int main() {
std::ios::sync_with_stdio(0), cin.tie(0), cout.tie(0);
int t = 1;
cin >> t;
while (t--) {
if (!solve()) cout << -1 << '\n';
}
return 0;
}
B
题解
知识点:贪心,枚举。
分两类,一种是纯 \(1\) 或 \(0\) ,另一种是杂合。
显然后者的情况中,把所有数字全选了是最优的;前者枚举一下所有纯子串即可。两种情况,取最大值。
时间复杂度 \(O(n)\)
空间复杂度 \(O(n)\)
代码
#include <bits/stdc++.h>
#define ll long long
using namespace std;
bool solve() {
int n;
cin >> n;
string s;
cin >> s;
s = "?" + s;
int cnt0 = 0, cnt1 = 0;
for (int i = 1;i <= n;i++) {
if (s[i] == '0') cnt0++;
else cnt1++;
}
ll mx = 1LL * cnt0 * cnt1;
int i = 1, j = 1;
while (i <= n) {
while (j <= n && s[j] == s[i]) j++;
mx = max(mx, 1LL * (j - i) * (j - i));
i = j;
}
cout << mx << '\n';
return true;
}
int main() {
std::ios::sync_with_stdio(0), cin.tie(0), cout.tie(0);
int t = 1;
cin >> t;
while (t--) {
if (!solve()) cout << -1 << '\n';
}
return 0;
}
C
题解
知识点:构造。
注意到,只有 \(a=b\) 或者 \(a\) 每位都不等于 \(b\) 的对应位才可行。
考虑先把 \(a\) 串的 \(1\) 一个一个消掉,然后发现 \(b\) 会出现全 \(0\) 全 \(1\) 的情况,接下来分类讨论:
- 如果 \(a = b\) ,那么 \(a\) 中 \(1\) 为偶数时得到的 \(b\) 是 \(0\) ,否则是 \(1\) 。
- 如果 \(a\) 每位都不等于 \(b\) 的对应位 ,那么消掉一个 \(1\) 以后又会回到情况1,因此和情况 \(1\) 相反。
全是 \(0\) 直接可以结束,全是 \(1\) 可以先把 \([1,n]\) 取反,然后选择 \([1,1],[2,n]\) 即可。
时间复杂度 \(O(n)\)
空间复杂度 \(O(n)\)
代码
#include <bits/stdc++.h>
#define ll long long
using namespace std;
bool solve() {
int n;
cin >> n;
string a, b;
cin >> a >> b;
a = "?" + a;
b = "?" + b;
int cnt = 0;
for (int i = 1;i <= n;i++) cnt += a[i] == b[i];
if (cnt != 0 && cnt != n) return 0;
bool flag = cnt == n ? 0 : 1;
vector<pair<int, int>> ans;
for (int i = 1;i <= n;i++) {
if (a[i] == '1') {
ans.push_back({ i, i });
flag ^= 1;
}
}
if (flag) {
ans.push_back({ 1,n });
ans.push_back({ 1,1 });
ans.push_back({ 2,n });
}
cout << "YES" << '\n';
cout << ans.size() << '\n';
for (auto [i, j] : ans) cout << i << ' ' << j << '\n';
return true;
}
int main() {
std::ios::sync_with_stdio(0), cin.tie(0), cout.tie(0);
int t = 1;
cin >> t;
while (t--) {
if (!solve()) cout << "NO" << '\n';
}
return 0;
}
D
题解
知识点:质因数分解,容斥原理,数论。
题目要求我们每个 \(b_i\) 的方案数,然后得到总的方案数。
显然有 \(gcd(a_{i-1},b_i) = a_i\) ,注意到 \(a_i\) 必须是 \(a_{i-1}\) 的因子否则不可能得到答案,因此特判一下 \(a_{i} | a_{i-1}\) 。
于是,我们要找到所有的 \(b_i\) ,满足 \(gcd(\frac{a_{i-1}}{a_i},\frac{b_i}{a_i}) = 1\) 且 \(a_i | b_i\) ,其中 \(\frac{b_i}{a_i} \in [1,\frac{m}{a_i}]\) ,即我们从 \([1,\frac{m}{a_i}]\) 整数中找到和 \(\frac{a_{i-1}}{a_i}\) 互素的个数。
这是一个典型的容斥问题。先对 \(\frac{a_{i-1}}{a_i}\) 分解素因数,得到其素因子种类。我们先计算出区间中包含 \(\frac{a_{i-1}}{a_i}\) 因子的数的个数,注意奇加偶减,然后用总数 \(\frac{m}{a_i}\) 减去个数,即与之互素的数的个数,于是我们就得到了 \(b_i\) 的种类。
遍历每个 \(a_i\) 即可。
时间复杂度 \(O(n(\log a_i + 10\cdot 2^{10}))\)
代码
#include <bits/stdc++.h>
#define ll long long
using namespace std;
const int mod = 998244353;
int a[200007];
bool vis[100007];
int prime[100007];
int cnt;
void euler_screen(int n) {
for (int i = 2;i <= n;i++) {
if (!vis[i]) prime[++cnt] = i;
for (int j = 1;j <= cnt && i * prime[j] <= n;j++) {
vis[i * prime[j]] = 1;
if (!(i % prime[j])) break;//如果到了i的最小质因子就不用继续,因为接下去的数x一定能被(i,x)之间的数筛掉
}
}
}///欧拉筛,O(n),每个合数只会被最小质因子筛掉
bool solve() {
int n, m;
cin >> n >> m;
for (int i = 1;i <= n;i++) cin >> a[i];
int ans = 1;
for (int i = 2;i <= n;i++) {
if (a[i - 1] % a[i]) {
ans = 0;
break;
}
int d = a[i - 1] / a[i];//不能出现的因子
int base = m / a[i];//包含a[i]的数个数
vector<int> ft;//对d分解因子种类
for (int j = 1;j <= cnt && prime[j] <= d / prime[j];j++) {
if (d % prime[j] == 0) ft.push_back(prime[j]);
while (d % prime[j] == 0) d /= prime[j];
}
if (d > 1) ft.push_back(d);
int sum = 0;//容斥原理,求[1,base]中没有d中因子的数个数
for (int j = 1; j < (1 << ft.size()); j++) {
int mul = 1, feat = 0;
for (int k = 0; k < ft.size(); k++) {
if (j & (1 << k)) {
mul *= ft[k];
feat++;
}
}
if (feat & 1) sum = (sum + 1LL * base / mul % mod) % mod;
else sum = (sum - 1LL * base / mul % mod + mod) % mod;
}
sum = (base - sum + mod) % mod;
ans = 1LL * ans * sum % mod;
}
cout << ans << '\n';
return true;
}
int main() {
std::ios::sync_with_stdio(0), cin.tie(0), cout.tie(0);
int t = 1;
cin >> t;
euler_screen(100007);
while (t--) {
if (!solve()) cout << -1 << '\n';
}
return 0;
}
CodeTON Round 3 (Div. 1 + Div. 2, Rated, Prizes!) A-D的更多相关文章
- Codeforces 1023 A.Single Wildcard Pattern Matching-匹配字符 (Codeforces Round #504 (rated, Div. 1 + Div. 2, based on VK Cup 2018 Fi)
Codeforces Round #504 (rated, Div. 1 + Div. 2, based on VK Cup 2018 Final) A. Single Wildcard Patter ...
- CF Intel Code Challenge Final Round (Div. 1 + Div. 2, Combined)
1. Intel Code Challenge Final Round (Div. 1 + Div. 2, Combined) B. Batch Sort 暴力枚举,水 1.题意:n*m的数组, ...
- Codeforces Beta Round #27 (Codeforces format, Div. 2)
Codeforces Beta Round #27 (Codeforces format, Div. 2) http://codeforces.com/contest/27 A #include< ...
- Codeforces Round #438 (Div.1+Div.2) 总结
本来兴致勃勃的想乘着这一次上紫,于是很早很早的到了机房 但是好像并没有什么用,反而rating-=47 Codeforces Round #438(Div.1+Div.2) 今天就这样匆匆的总结一下, ...
- Manthan, Codefest 19 (open for everyone, rated, Div. 1 + Div. 2)-D. Restore Permutation-构造+树状数组
Manthan, Codefest 19 (open for everyone, rated, Div. 1 + Div. 2)-D. Restore Permutation-构造+树状数组 [Pro ...
- Manthan, Codefest 19 (open for everyone, rated, Div. 1 + Div. 2)-C. Magic Grid-构造
Manthan, Codefest 19 (open for everyone, rated, Div. 1 + Div. 2)-C. Magic Grid-构造 [Problem Descripti ...
- Manthan, Codefest 19 (open for everyone, rated, Div. 1 + Div. 2)-E. Let Them Slide-思维+数据结构
Manthan, Codefest 19 (open for everyone, rated, Div. 1 + Div. 2)-E. Let Them Slide-思维+数据结构 [Problem ...
- Codeforces Round #792 (Div. 1 + Div. 2) A-E
Codeforces Round #792 (Div. 1 + Div. 2) A-E A 题目 https://codeforces.com/contest/1684/problem/A 题解 思路 ...
- Codeforces Round #792 (Div. 1 + Div. 2) // C ~ E
比赛链接:Dashboard - Codeforces Round #792 (Div. 1 + Div. 2) - Codeforces C. Column Swapping 题意: 给定一个n*m ...
- 【codeforces】【比赛题解】#868 CF Round #438 (Div.1+Div.2)
这次是Div.1+Div.2,所以有7题. 因为时间较早,而且正好赶上训练,所以机房开黑做. 然而我们都只做了3题.:(. 链接. [A]声控解锁 题意: Arkady的宠物狗Mu-mu有一只手机.它 ...
随机推荐
- ARC122D XOR Game(博弈论?字典树,贪心)
题面 ARC122D XOR Game 黑板上有 2 N 2N 2N 个数,第 i i i 个数为 A i A_i Ai. O I D \rm OID OID(OneInDark) 和 H I D ...
- 未完待续【java】JavaEE学习路线总览
这个博客会详细介绍各种技术的知识点,从零基础到入门,充当引路的作用. 同时也会发布一些Swift语言.c#语言.Xcode开发的学习笔记.一些阅读的笔记(部分读书笔记无法发布). 目前1-43的Jav ...
- [开源精品] C#.NET im 聊天通讯架构设计 -- FreeIM 支持集群、职责分明、高性能
FreeIM 是什么? FreeIM 使用 websocket 协议实现简易.高性能(单机支持5万+连接).集群即时通讯组件,支持点对点通讯.群聊通讯.上线下线事件消息等众多实用性功能. ImCore ...
- 面试突击79:Bean 作用域是啥?它有几种类型?
Spring 框架作为一个管理 Bean 的 IoC 容器,那么 Bean 自然是 Spring 中的重要资源了,那 Bean 的作用域是什么意思?又有几种类型呢?接下来我们一起来看. PS:Java ...
- C# 开发过程中常见错误记录及解决说明
1.异常了类型: 1.1.1.1 异常错误信息:An error occurred while updating the entries. See the inner exception for de ...
- KingbaseES R6 集群主库网卡down测试案例
数据库版本: test=# select version(); version ------------------------------------------------------------ ...
- Java---Stream进阶
由于本文需要有一定的Stream基础,所以如果不懂什么是Stream的同学请移步:Java---Stream入门 操作分类 graph LR 操作分类 --- 中间操作 终端操作 --- 操作分类 中 ...
- 《吐血整理》高级系列教程-吃透Fiddler抓包教程(22)-如何使用Fiddler生成Jmeter脚本-下篇
1.简介 今天这篇文章其实和上一篇差不多也是利用一个fiddler的插件进行Jmeter脚本的导出,开始宏哥想要合在一起写一篇文章,可是结果实践的时候,两个插件还是有区别的,因此为了不绕晕小伙伴或者童 ...
- 工程课Linux第一节笔记
上课笔记 文件系统结构 /根目录 /bin/ 存放系统命令,普通用户与root都可以执行 /etc/ 配置文件保存位置 /lib/ 系统调用的函数库保存位置 /var/ 目录用于存储动态数据,例如缓存 ...
- Dapr 集成 Open Policy Agent
大型项目中基本都包含有复杂的访问控制策略,特别是在一些多租户场景中,例如Kubernetes中就支持RBAC,ABAC等多种授权类型.Dapr 的 中间件 Open Policy Agent 将Reg ...