比赛链接:https://codeforces.com/contest/1492

1492A.Three swimmers

题意:

有三名游泳的人,他们分别需要 \(a,b,c\) 分钟才能在一个游泳池游一个来回,第一个游泳者将在开始时间 \(0,a,2a,3a,…\) 分钟后在游泳池的左侧,第二个游泳者将在 \(0,b,2b,3b,…\) 分钟后,第三个将在 \(0,c,2c,3c,…\) 分钟后出现在池的左侧。

\(p\)​ 分钟后最少需要等待多长时间会有一个游泳者到达游泳池左侧。

思路:

签到题,

可以暴力遍历 \(a,b,c\) 寻找最小值,

也可以直接找 \(a,b,c\) 的倍数离 \(p\)​​ 差多少

注意开 long long....

【AC Code】

int main() {
ios::sync_with_stdio(false), cin.tie(nullptr);
int _; for (cin >> _; _--;) {
ll p, a, b, c;
cin >> p >> a >> b >> c;
if (p % a == 0 || p % b == 0 || p % c == 0)
cout << "0\n";
else cout << min(a - p % a, min(b - p % b, c - p % c)) << "\n";
}
}

1492B. Card Deck

题意:

有 \(n\) 张卡,每张卡的值 \(1\sim n\),等于 \(p_i\),\(p_1\) 代表底卡,\(p_n\) 是顶卡,在每个步骤中,选择一些 \(k > 0\) 的整数,从原始卡片组中取出前 \(k\) 张卡片,然后按它们现在的顺序将它们放置在新卡片组的顶部。让阶数最大。

思路:

找最大的数输出最大的数加后边的所有数,接着找第二个······注意不要重复输出

【AC Code】

const int N = 1e5 + 10;
ll a[N], pos[N];
bool st[N];
int main() {
ios::sync_with_stdio(false), cin.tie(nullptr);
int _; for (cin >> _; _--;) {
vector<int>A;
int n; cin >> n;
for (int i = 1; i <= n; ++i) {
cin >> a[i];
pos[i] = i;
st[a[i]] = 0;
}
ll t = n;
for (ll i = n; i >= 1; i -= 1) {
if (a[i] == t)
for (ll j = i; !st[a[j]] && j <= n; j += 1) {
st[a[j]] = 1;
A.emplace_back(a[j]);
}
while (st[t] && t >= 1) t -= 1;
}
for (ll i = 0; i < n; i += 1) cout << A[i] << " \n"[i == n - 1];
}
}

1492C. Maximum width

题意:

给你两个字符串 \(s,t\) 找 \(s\) 串和 \(t\) 串匹配的下标,然后找相邻下标之间的最大值,管你懂不懂看样例就完事了

思路:

看了半天样例发现只需要前后扫一遍,分别用两个数组去存前后扫的下标结果,取两个数组相邻位置的最大值

【AC Code】

const int N = 2e5 + 10;
int n, m, a[N], b[N];
string s, t;
int main() {
ios::sync_with_stdio(false), cin.tie(nullptr);
cin >> n >> m >> s >> t;
int i = 0, j = 0;
while (j < m) {
if (s[i] == t[j]) {
a[j] = i + 1;
i ++; j ++;
} else i ++;
}
i = n - 1, j = m - 1;
while (j > 0) {
if (s[i] == t[j]) {
b[j] = i + 1;
i --; j --;
} else i --;
}
int ans = 0;
for (int q = 0; q < m; q ++)
ans = max(ans, b[q + 1] - a[q]);
cout << ans << "\n";
}

1492D. Genius’s Gambit

题意:

给你三个数,\(a\) 代表 \(0\) 的个数,\(b\) 代表 \(1\) 的个数,\(k\) 代表 \(x-y\) 中 \(1\) 的个数,让你求出 \(x,y\) 满足 \(a,b,k\) 三个条件,如果没有输出 NO

思路:

构造题,说实话赛时没构造出来,这里参考了一下题解

由题目可知 \(x>y\) 是肯定的,所以我们不妨假设 \(x,y为11…00…\) ,然后对 \(y\) 进行变换,我们发现 \(y\) 最右边的1往后移动一位 \(x-y\) 的值就多一个 \(1\) ,最大为 \(a\)​ ,然后移动倒数第二个 \(1\) ,发现只能移动一次,如果移动两次不会多一个 \(1\)​ 。

假设

x 1110000

y 1110000

当 \(y\) 的倒数第一个 \(1\) 往右移动时发现 \(x-y\) 中 \(1\) 的个数 \(+1\) ,当y 1100001时 \(x-y\) 中 \(1\) 的个数为 \(4\) ,然后移动倒数第二个 \(1\),移动一次,发现 \(x-y\) 中 \(1\) 的个数变成了 \(5\) ,再移动一次发现又变回 \(4\) ,所以除了倒数第一个 \(1\) 可以移动多次,第一个 \(1\) 不能移动中间的 \(1\) 只能移动一次,我们可以找出规律,最大的值为 \(a+b-2\)​​​ 。

【AC Code】

int a, b, k;

int main(void) {
cin.tie(0);
ios::sync_with_stdio(false);
cin >> a >> b >> k;
if (k == 0) {
cout << "Yes" << '\n';
string x = "", y = "";
x += '1';
b--;
for (int i = 0; i < a; i++) x += '0';
for (int i = 0; i < b; i++) x += '1';
cout << x << '\n';
cout << x << '\n';
return 0;
}
k--;
if (a > 0 && b >= 2 && (a + b - 3 >= k)) {
cout << "Yes" << '\n';
string x = "";
string y = "";
a--; b -= 2;
x += '1'; y += '1'; x += '1'; y += '0';
for (int i = 0; i < k; i++) {
if (a) {
a--;
x += '0'; y += '0';
} else {
b--;
x += '1'; y += '1';
}
}
x += '0'; y += '1';
while (a--) {
x += '0'; y += '0';
}
while (b--) {
x += '1'; y += '1';
} cout << x << '\n';
cout << y << '\n';
} else
cout << "No" << '\n';
}

模拟构造,我不会(QAQ

1492E. Almost Fault-Tolerant Database

题意:

给定 \(n\) 个长度为 \(m\) 的数组,需要输出一个长度为 \(m\) 的数组,使得这些数组之间不同的数不超过两个,输出YES,输出你构造的数组,若有多种情况,可任意输出一种。如若不存在,输出NO。

思路:

假设第一个数组为标准数组,遍历

  1. 不同数小于等于 \(2\),没问题
  2. 不同数大于 \(4\) ,直接输出NO
  3. 就是 \(3,4\) 的情况,我们找差异数最大的那个也就是 \(4\) 的情况,枚举修改的两个位置,判断是否可以成立。

【AC Code】

const int N = 250010;
int n, m;
vector <int> s[N];
bool check2(vector<int> &v) {
for (int i = 1; i < n; i ++) {
int cnt = 0;
for (int j = 0; j < m; j ++)
if (s[i][j] != v[j]) cnt ++; if (cnt > 3) return false;
else if (cnt == 3) {
int ans = 1;
for (int j = 0; j < m; j ++) {
if (s[i][j] != v[j] && v[j] == -1) {
ans = 0;
v[j] = s[i][j];
break;
}
}
if (ans) return false;
}
}
return true;
} bool check() {
int cnt = 0, ax = 0, id;
for (int i = 1; i < n; i ++) {
int ans = 0;
for (int j = 0; j < m; j ++)
if (s[i][j] != s[0][j]) ans ++; if (ans > 4) return false;
if (ans <= 2) cnt ++;
if (ans > ax)ax = ans, id = i;
} if (cnt == n - 1) {
cout << "Yes\n";
for (int i = 0; i < m; ++i) cout << s[0][i] << " \n"[i == m - 1];
return true;
} vector<int> a;
for (int i = 0; i < m; i ++)
if (s[0][i] != s[id][i]) a.push_back(i); for (int i = 0; i < a.size(); i ++) {
for (int j = 0; j < a.size(); j ++) {
if (i == j) continue; vector<int> b = s[0]; b[a[i]] = s[id][a[i]];
b[a[j]] = -1; if (check2(b)) {
cout << "Yes\n";
for (int i = 0; i < m; ++i) cout << (b[i] == -1 ? s[0][i] : b[i]) << " \n"[i == m - 1];
return true;
}
}
}
return false;
} int main() {
ios::sync_with_stdio(false), cin.tie(nullptr);
cin >> n >> m;
for (int i = 0; i < n; i ++) {
for (int j = 0, x; j < m; j ++) {
cin >> x;
s[i].push_back(x);
}
}
if (!check()) puts("No");
}

Codeforces Round #704 (Div. 2) A~E的更多相关文章

  1. Codeforces Round #704 (Div. 2), problem: (C) Maximum width还是要多学习

    Problem - C - Codeforces 看清题目要求, 最重要部分在第二段. 大佬最后给出的代码果然简单, 思路简单化, 未必非要把答案在一个大括号里全部完成, 两个指针同时跑,中间加了一堆 ...

  2. Codeforces Round #704 (Div. 2)

    A. Three swimmers 题意:第一个人跳水是每隔a分钟去一次,第二个人跳水是每隔b分钟,第三个人跳水是每隔c分钟,一个人准备在p分钟的 时候去跳水,问需要最少等待多长时间才能轮到前三个人 ...

  3. Codeforces Round #366 (Div. 2) ABC

    Codeforces Round #366 (Div. 2) A I hate that I love that I hate it水题 #I hate that I love that I hate ...

  4. Codeforces Round #354 (Div. 2) ABCD

    Codeforces Round #354 (Div. 2) Problems     # Name     A Nicholas and Permutation standard input/out ...

  5. Codeforces Round #368 (Div. 2)

    直达–>Codeforces Round #368 (Div. 2) A Brain’s Photos 给你一个NxM的矩阵,一个字母代表一种颜色,如果有”C”,”M”,”Y”三种中任意一种就输 ...

  6. cf之路,1,Codeforces Round #345 (Div. 2)

     cf之路,1,Codeforces Round #345 (Div. 2) ps:昨天第一次参加cf比赛,比赛之前为了熟悉下cf比赛题目的难度.所以做了round#345连试试水的深浅.....   ...

  7. Codeforces Round #279 (Div. 2) ABCDE

    Codeforces Round #279 (Div. 2) 做得我都变绿了! Problems     # Name     A Team Olympiad standard input/outpu ...

  8. Codeforces Round #262 (Div. 2) 1003

    Codeforces Round #262 (Div. 2) 1003 C. Present time limit per test 2 seconds memory limit per test 2 ...

  9. Codeforces Round #262 (Div. 2) 1004

    Codeforces Round #262 (Div. 2) 1004 D. Little Victor and Set time limit per test 1 second memory lim ...

  10. Codeforces Round #371 (Div. 1)

    A: 题目大意: 在一个multiset中要求支持3种操作: 1.增加一个数 2.删去一个数 3.给出一个01序列,问multiset中有多少这样的数,把它的十进制表示中的奇数改成1,偶数改成0后和给 ...

随机推荐

  1. Python有四个数字:1、2、3、4,能组成多少个互不相同且无重复数字的三位数?各是多少?

    n = 0 for i in range(1, 5): for j in range(1, 5): for k in range(1, 5): if(i != k) and (i != j) and ...

  2. 【Android】【外包杯】后台管理系统 | 进度day01

    外包杯官方提示:平台不要太大,只是一些小东西包括支付宝和微信小程序打开,无需安装口香糖,餐巾纸有一块屏幕,不需要很大,只需要满足顾客可以看到传播的内容打开橱窗不要有锋利边角,不要求一体,提高场景利用率 ...

  3. 聊一聊 .NET高级调试 中必知的符号表

    一:背景 1. 讲故事 在高级调试的旅行中,发现有不少人对符号表不是很清楚,其实简而言之符号表中记录着一些程序的生物特征,比如哪个地址是函数(签名信息),哪个地址是全局变量,静态变量,行号是多少,数据 ...

  4. .NET8 AOT和JIT的性能,谁更高呢?

    一: 有人问:.NET8 AOT和JIT的性能,谁更高呢? 原文:.NET8 AOT和JIT的性能,谁更高呢? 其实这个答案非常明显,那就是JIT的性能更高.为什么?原因在哪?因为JIT是随时可能分层 ...

  5. CICD实践1:环境安装篇

    一.CICD技术选型 配置管理工具 工具 需求管理工具 使用禅道 代码管理工具 使用Gitlab 编译构建工具 搭建Jenkins,使用Jenkinsfile 制品库工具 nexus 文档管理工具 C ...

  6. 为什么说数字孪生和GIS高度互补?它们各自从对方那里获得了什么?

    在数字化时代,数字孪生和GIS作为两项重要技术,它们的融合正日益受到人们的关注和认可.数字孪生是将实体世界与数字世界紧密结合的技术,可以创建实时的虚拟副本,对物理系统进行模拟.优化和预测.而GIS则是 ...

  7. ImportError: No module named pypinyin

    import platform, subprocess, os, zipfile, xml, re, pypinyin ImportError: No module named pypinyin pi ...

  8. C++ Qt开发:TableView与TreeView组件联动

    Qt 是一个跨平台C++图形界面开发库,利用Qt可以快速开发跨平台窗体应用程序,在Qt中我们可以通过拖拽的方式将不同组件放到指定的位置,实现图形化开发极大的方便了开发效率,本章将重点介绍TableVi ...

  9. JMeter变量和调试取样器

    变量 可以在测试计划中定义变量 可以通过${变量名}进行调用 调试取样器可以看到变量参数

  10. 春秋云镜 - CVE-2022-28512

    Fantastic Blog (CMS)是一个绝对出色的博客/文章网络内容管理系统.它使您可以轻松地管理您的网站或博客,它为您提供了广泛的功能来定制您的博客以满足您的需求.它具有强大的功能,您无需接触 ...