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

A - Road To Zero

题意

有两个非负整数 x, y 以及两种操作:

  • 支付 a 点代价使其中一个数加一或减一
  • 支付 b 点代价使两个数都加一或减一

问使二者为 0 的最小代价。

思路

把较大的数减至与较小数相等再选取 min(2 * a, b) 把二者减为 0 即可。

代码

#include <bits/stdc++.h>
using namespace std; void solve() {
long long x, y, a, b; cin >> x >> y >> a >> b;
cout << min(2 * a, b) * min(x, y) + a * (max(x, y) - min(x, y)) << "\n";
} int main() {
int t; cin >> t;
while (t--) solve();
}

B - Binary Period

题意

给定 01 串 t,构造 01 串 s,要求满足:

  • 长度不超过 2 * | t |
  • t 为 s 的一个子序列
  • s 由最短的字符串重复而成

思路

如果 t 中只含有一种字符直接输出 t 即可,否则对于 t 中的每位均用“01”代替。

代码

#include <bits/stdc++.h>
using namespace std; void solve() {
string t; cin >> t;
int zero = 0, one = 0;
for (char c : t)
if (c == '0') zero = 1;
else one = 1;
if (zero + one == 1) cout << t << "\n";
else {
for (int i = 0; i < t.size(); i++)
cout << "01";
cout << "\n";
}
} int main() {
int t; cin >> t;
while (t--) solve();
}

C - Yet Another Counting Problem

题意

给你两个正整数 a, b,回答 q 次询问:[l, r] 区间中有多少数 x % a % b != x % b % a 。

思路

观察到条件为 x % a % b != x % b % a,可以联想到 (x + lcm(a, b)) % a % b != (x + lcm(a, b)) % b % a ,所以只需计算 [1, lcm] 区间内满足条件的数的个数,然后计算 [1, l - 1], [1, r] 中各有多少个长为 lcm 的区间,考虑到可能有不完全包含区间,所以可以计算 [1, lcm] 内的前缀和,查询长度对 lcm 取余对应的前缀和即为不完全包含区间中满足条件的数的个数。

代码

#include <bits/stdc++.h>
using LL = long long;
using namespace std; void solve() {
int a, b, q; cin >> a >> b >> q;
int lcm = a * b / __gcd(a, b);
int cnt[lcm + 1] = {};
for (int i = 1; i <= lcm; i++) {
cnt[i] = cnt[i - 1] + (i % a % b != i % b % a);
}
auto f = [&] (LL n) -> LL {
return cnt[lcm] * (n / lcm) + cnt[n % lcm];
};
for (int i = 0; i < q; i++) {
LL l, r; cin >> l >> r;
cout << f(r) - f(l - 1) << " \n"[i == q - 1];
}
} int main() {
int t; cin >> t;
while (t--) solve();
}

D - Multiple Testcases

题意

将 n 个数分为尽可能少的数组,要求每个数组中大于等于 i 的数不超过 ci 个。

思路

一种较为简便的方法是:利用后缀和算出大于等于 i 的数共有多少个,最少需要的数组即为 $max \lceil \frac{n_i}{c_i} \rceil$,之后从小到大循环推入数组元素。但是这种贪心的原理仍有待证明。

代码

#include <bits/stdc++.h>
using namespace std;
int main() {
int n, k; cin >> n >> k;
int suf[k + 1] = {};
int m[n]; for (int &i : m) cin >> i, ++suf[i - 1];
int c[k]; for (int &i : c) cin >> i;
int ans = 0;
for (int i = k - 1; i >= 0; i--) {
suf[i] += suf[i + 1];
ans = max(ans, (suf[i] - 1) / c[i] + 1);
}
vector<int> vec[ans];
sort(m, m + n);
for (int i = 0; i < n; i++)
vec[i % ans].push_back(m[i]);
cout << ans << "\n";
for (auto v : vec) {
cout << v.size();
for (auto i : v) cout << ' ' << i;
cout << "\n";
}
}

Educational Codeforces Round 86 (Div. 2)的更多相关文章

  1. Educational Codeforces Round 84 (Div. 2)

    Educational Codeforces Round 84 (Div. 2) 读题读题读题+脑筋急转弯 = =. A. Sum of Odd Integers 奇奇为奇,奇偶为偶,所以n,k奇偶性 ...

  2. Educational Codeforces Round 58 Div. 2 自闭记

    明明多个几秒就能场上AK了.自闭. A:签到. #include<iostream> #include<cstdio> #include<cmath> #inclu ...

  3. Educational Codeforces Round 47 (Div 2) (A~G)

    目录 Codeforces 1009 A.Game Shopping B.Minimum Ternary String C.Annoying Present D.Relatively Prime Gr ...

  4. Educational Codeforces Round 46 (Div 2) (A~G)

    目录 Codeforces 1000 A.Codehorses T-shirts B.Light It Up C.Covered Points Count(差分) D.Yet Another Prob ...

  5. Educational Codeforces Round 45 (Div 2) (A~G)

    目录 Codeforces 990 A.Commentary Boxes B.Micro-World C.Bracket Sequences Concatenation Problem D.Graph ...

  6. Educational Codeforces Round 85 (Div. 2)

    题目链接:https://codeforces.com/contest/1334 A. Level Statistics 题意 一个关卡有玩家的尝试次数和通关次数,按时间顺序给出一个玩家 $n$ 个时 ...

  7. Educational Codeforces Round 119 (Div. 2), (C) BA-String硬着头皮做, 能做出来的

    题目链接 Problem - C - Codeforces 题目 Example input 3 2 4 3 a* 4 1 3 a**a 6 3 20 **a*** output abb abba b ...

  8. Educational Codeforces Round 108 (Div. 2), C map套vector存储

    地址  Problem - C - Codeforces 题目 题意 一个学校有n个人参加比赛,他们分别属于ui队,每个人的能力值为si 当每个队需要1~n个人的时候,这个学校能参加的人的能力值和最大 ...

  9. Educational Codeforces Round 62 Div. 2

    突然发现上一场edu忘记写了( A:签到. #include<iostream> #include<cstdio> #include<cmath> #include ...

随机推荐

  1. 图像质量评估论文 | Deep-IQA | IEEETIP2018

    主题列表:juejin, github, smartblue, cyanosis, channing-cyan, fancy, hydrogen, condensed-night-purple, gr ...

  2. pip不是内部或外部命令解决方法

    问题 已经配置好Python环境,但是安装依赖时,出现pip不是内部或外部命令. 解决方法 找到pip.exe文件所在的目录,将所在路径配置到环境变量path中. 再次输入pip

  3. 腾讯QQ,人人都是高手

    今天,腾讯果然给出了官方回应,具体表述如下: 可能你看不太懂,其实我也看的不太懂,不过这就是公关的能力体现,就像我"人人都是高手"的大连车务组微机室小编一样,把一个降级flash描 ...

  4. 【RAC】双节点RAC搭建

    本文主要是双节点的RAC进行搭建,根据黄伟老师的视频进行总结和使用. 搭建环境: 1.两台安装好Linux_x64系统的服务器 2.IP设置 注意:Priv-IP的IP是自己一个网段,而剩下的SCAN ...

  5. PYTHON爬虫实战_垃圾佬闲鱼爬虫转转爬虫数据整合自用二手急速响应捡垃圾平台_3(附源码持续更新)

    说明 文章首发于HURUWO的博客小站,本平台做同步备份发布. 如有浏览或访问异常图片加载失败或者相关疑问可前往原博客下评论浏览. 原文链接 PYTHON爬虫实战_垃圾佬闲鱼爬虫转转爬虫数据整合自用二 ...

  6. C++ STL getline()函数

    getline() C++11 <string> 函数原型 //(1) istream& getline (istream& is, string& str, ch ...

  7. MyBatis初级实战之六:一对多关联查询

    欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...

  8. SDNU_ACM_ICPC_2021_Winter_Practice_1st [个人赛] 2021.1.19 星期二

    SDNU_ACM_ICPC_2021_Winter_Practice_1st [个人赛] K - Color the ball 题意: 有n个气球,每次都给定两个整数a,b,给a到b内所有的气球涂一个 ...

  9. 《进击吧!Blazor!》第一章 1.初识 Blazor

    作者介绍 陈超超 Ant Design Blazor 项目贡献者 拥有十多年从业经验,长期基于.Net技术栈进行架构与开发产品的工作,Ant Design Blazor 项目贡献者,现就职于正泰集团 ...

  10. kafka项目经验之如何进行Kafka压力测试、如何计算Kafka分区数、如何确定Kaftka集群机器数量

    @ 目录 Kafka压测 Kafka Producer(生产)压力测试 Kafka Consumer(消费)压力测试 计算Kafka分区数 Kafka机器数量计算 Kafka压测 用Kafka官方自带 ...