Codeforces Round #734 (Div. 3) A~D1 个人题解
比赛链接:Here
1551A. Polycarp and Coins (签到)
题意:
我们有任意个面额为 \(1\) 和 \(2\) 的硬币去支付 \(n\) 元账单,
现在请问怎么去分配数额使得 \(c_1 +2 * c_2 = n\) 并且要最小化 \(|c_1-c_2|\)
贪心,
很容易想到最小化 \(|c_1 - c_2|\) 等于 \(0\) 或 \(1\)
int main() {
cin.tie(nullptr)->sync_with_stdio(false);
int _; for (cin >> _; _--;) {
int n;
cin >> n;
if (n % 3 == 0) cout << n / 3 << " " << n / 3 << "\n";
else if (n % 3 == 1) cout << n / 3 + 1 << " " << n / 3 << "\n";
else cout << n / 3 << " " << n / 3 + 1 << "\n";
}
}
1551B1. Wonderful Coloring - 1(easy)
题意:
给定长度为 \(n\) 的字符串和 \(k = 2\) 种颜色,
对于字符串每一个位置要么不涂颜色,要么每种颜色的字母都要不同并且最后 \(k\) 种颜色涂的个数相同
请输出每种颜色最后的个数
统计 26 个字母出现次数,然后出现超过 2 的+1,仅出现一次的个数 / 2即可(易证明)
int main() {
cin.tie(nullptr)->sync_with_stdio(false);
int _; for (cin >> _; _--;) {
string s;
cin >> s;
int a[30] = {0};
for (int i = 0; i < int(s.length()); ++i) {
a[s[i] - 'a']++;
}
int a2 = 0, a1 = 0;
for (int i = 0; i < 26; ++i) {
if (a[i] == 1)a1++;
if (a[i] > 1)a2++;
}
cout << a1 / 2 + a2 << "\n";
}
}
1551B2. Wonderful Coloring - 2 (hard版本)
题意基本同 B1 一致,
但需输出每个位置数字涂的颜色
写了两罚模拟 \(\mathcal{O}(n^2)\) 不出所料肯定 T了,
转换一下思路,首先和 B1 一样我们需要去统计每种数字的个数,但由于最后需要输出每个位置的颜色编号,所以还得存一下下标 (pos)
- \(cnt[a[i]] \le k\) 的将下标存储
- \(cnt[a[i]] > k\) 无需使用标 \(0\)
当然对于多余的元素,可以直接从删除
while (pos.size() % k != 0)pos.pop_back();
此时 pos 中所有元素均为有效下标,我们只要对应原数组标记颜色编号即可
int main() {
cin.tie(nullptr)->sync_with_stdio(false);
int _; for (cin >> _; _--;) {
int n, k;
cin >> n >> k;
vector<int>a(n), cnt(n);
vector<int>pos;
for (int i = 0; i < n; ++i) {
cin >> a[i], a[i] -= 1;
cnt[a[i]] += 1;
if (cnt[a[i]] <= k) pos.push_back(i);
}
while (pos.size() % k != 0)pos.pop_back();
sort(pos.begin(), pos.end(), [&](int i, int j) {return a[i] < a[j];});
vector<int>ans(n);
for (int i = 0; i < pos.size(); ++i)
ans[pos[i]] = i % k + 1;
for (int i = 0; i < n; ++i)
cout << ans[i] << " \n"[i == n - 1];
}
}
1551C. Interesting Story
题意:
一个作家有 \(n\) 个单词,每一个单词只会由 a,b,c,d,e 构成,他想用 \(m(0\le m\le n)\) 个单词写一个故事
一个故事是否有趣在于:
故事中存在一个字母的个数比其他字母个数的总和还更多
比如:
bac,aaada,e三个单词,a出现的次数比其他 4 种单词出现次数都多
请输出在保证故事有趣的情况下用更多的单词写故事
这里建议直接看代码便于理解
【AC Code】代码参考于比赛 高Rank dalao
int main() {
cin.tie(nullptr)->sync_with_stdio(false);
int _; for (cin >> _; _--;) {
int n;
cin >> n;
vector<string>s(n);
for (int i = 0; i < n; ++i) cin >> s[i];
int ans = 0;
for (int c = 0; c < 5; ++c) {
vector<int>f(n);
for (int i = 0; i < n; ++i) {
for (auto x : s[i])
if (x == 'a' + c)f[i]++;
else f[i]--;
}
sort(f.begin(), f.end(), greater<int>());
int sum = 0;
for (int i = 0; i < n; ++i) {
sum += f[i];
if (sum <= 0)break;
ans = max(ans, i + 1);
}
}
cout << ans << "\n";
}
}
很好奇自己是怎么读题读成使用连续的单词去写故事的啊?kola
1551D1. Domino (easy version)
题意:待补
多米诺骨牌的排放似乎在ABC的某一场也出现过
如果 \(n\) 为奇数
- 最少要横放 \(m / 2\) 个,不然最少 \(0\) 个
- 最多 \(n * m / 2 = (m \% 2 == 1 ?\ n / 2 : 0)\) 个
对于给出的 \(k\) 只要在 \([mn,mx]\) 就输出 YES
int main() {
cin.tie(nullptr)->sync_with_stdio(false);
int _; for (cin >> _; _--;) {
int n, m, k;
cin >> n >> m >> k;
int mn = (n % 2 == 1 ? m / 2 : 0);
int mx = n * m / 2 - (m % 2 == 1 ? n / 2 : 0);
if (mn <= k and k <= mx and (k - mn) % 2 == 0) cout << "YES\n";
else cout << "NO\n";
}
}
Codeforces Round #734 (Div. 3) A~D1 个人题解的更多相关文章
- 刷题记录:Codeforces Round #734 (Div. 3)
Codeforces Round #734 (Div. 3) 20210920.网址:https://codeforces.com/contest/1551. 编程细节:下标定义不要一会[1,n]一会 ...
- Codeforces Round #609 (Div. 2)前五题题解
Codeforces Round #609 (Div. 2)前五题题解 补题补题…… C题写挂了好几个次,最后一题看了好久题解才懂……我太迟钝了…… 然后因为longlong调了半个小时…… A.Eq ...
- Codeforces Round #741 (Div. 2), problem: (D1) Two Hundred Twenty One (easy version), 1700
Problem - D1 - Codeforces 题意: 给n个符号(+或-), +代表+1, -代表-1, 求最少删去几个点, 使得 题解(仅此个人理解): 1. 这题打眼一看, 肯定和奇 ...
- Codeforces Round #556 (Div. 2) D. Three Religions 题解 动态规划
题目链接:http://codeforces.com/contest/1150/problem/D 题目大意: 你有一个参考串 s 和三个装载字符串的容器 vec[0..2] ,然后还有 q 次操作, ...
- Codeforces Round #604 (Div. 2) E. Beautiful Mirrors 题解 组合数学
题目链接:https://codeforces.com/contest/1265/problem/E 题目大意: 有 \(n\) 个步骤,第 \(i\) 个步骤成功的概率是 \(P_i\) ,每一步只 ...
- Codeforces Round #624 (Div. 3) F. Moving Points 题解
第一次写博客 ,请多指教! 翻了翻前面的题解发现都是用树状数组来做,这里更新一个 线段树+离散化的做法: 其实这道题是没有必要用线段树的,树状数组就能够解决.但是个人感觉把线段树用熟了会比树状数组更有 ...
- Codeforces Round #677 (Div. 3) E、G题解
E. Two Round Dances #圆排列 题目链接 题意 \(n\)(保证偶数)个人,要表演一个节目,这个节目包含两种圆形舞蹈,而每种圆形舞蹈恰好需要\(n/2\)个人,每个人只能跳一种圆形舞 ...
- Codeforces Round#402(Div.1)掉分记+题解
哎,今天第一次打div1 感觉头脑很不清醒... 看到第一题就蒙了,想了好久,怎么乱dp,倒过来插之类的...突然发现不就是一道sb二分吗.....sb二分看了二十分钟........ 然后第二题看了 ...
- Codeforces Round #604 (Div. 2) 练习A,B题解
A题 链接 思路分析: 因为只需要做到相邻的不相同,利用三个不同的字母是肯定可以实现的, 所以直接先将所有的问号进行替换,比如比前一个大1,如果与后面的冲突,则再加一 代码(写的很烂): #inclu ...
- Codeforces Round #599 (Div. 2)的简单题题解
难题不会啊…… 我感觉写这个的原因就是因为……无聊要给大家翻译题面 A. Maximum Square 简单题意: 有$n$条长为$a_i$,宽为1的木板,现在你可以随便抽几个拼在一起,然后你要从这一 ...
随机推荐
- 一篇文章带你掌握Web自动化测试工具——Selenium
一篇文章带你掌握Web自动化测试工具--Selenium 在这篇文章中我们将会介绍Web自动化测试工具Selenium 如果我们需要学习相关内容,我们需要掌握Python,PyTest以及部分前端知识 ...
- 用友vs金蝶产品分析(云星空与YonSuite)
产品定位 用友与金蝶二者面对的客户群体是相同的:都是为成长型企业提供一体化服务,由于金蝶云星空发展较早,在部分产品功能上具备一定的先发优势:在产品的架构上,由于YS采用目前最先进的云原生和微服务架构, ...
- AntDesignBlazor示例——新建项目
本示例是AntDesign Blazor的入门示例,在学习的同时分享出来,以供新手参考. 1. 开发环境 VS2022 17.8.2 .NET8 AntDesign 0.16.2 2. 学习目标 创建 ...
- 从零开始的 dbt 入门教程 (dbt-core 基础篇)
最近一直在处理数据分析和数据建模的事情,所以接触了 dbt 等数据分析的工具,国内目前对于 dbt 比较详细的资料不多,所以打算写四道五篇 dbt 相关的文章,本文属于 dbt 系列的第一篇,本篇主要 ...
- Vue入门(1)安装vue环境,创建Vue2 Vue3的项目并且安装IIS环境和发布到IIS
Vue环境的搭建 一. 背景 vue的运行方式有两种 一种是在页面引用vue的js包, 一种是搭建脚手架来vue框架. 我们在这里使用的是第二种方式. 需要安装的软件 npm 16.13.1 ...
- [计蒜客20191103C] 分组
小 C 是 \(n\) 个学生的老师,他现在要把所有学生分成两组,他会按照以下这些要求: 1.如果两个同学是好朋友那么他们就不会被分到同一组 2.小 C 想最小化两组人数差值 现在请你写一个程序来帮助 ...
- [研究]SpringBoot-MybatisPlus-Dynamic(多数据源)
SpringBoot-MybatisPlus-Dynamic(多数据源) 前言 基于工作上班累死了...打开自己电脑 不知道干些啥 就康康 PL 网站康康 更新了啥 咦~~~还挺多 看到了多数 ...
- Codeforce Round 916(div3)
Codeforces Round 916(div3) [Problem - A - Codeforces]:Problemsolving Log A.题 直接看样例进行分析,发现每一次出现的字符代表着 ...
- Plant-Earth-wp
Earth 信息收集 开放了80,443 只能访问到443,试了试msf里面frado的远古rce都不成功.然后注意到有域名解析 添加到hosts里面再访问,当前页面有几串密文,经尝试在message ...
- 在centos7.9中 修改docker0 的网卡默认IP地址
docker0网卡的默认IP地址为172.17.0.1/16 因此很可能会与企业网中的业务地址冲突,为了解决这个问题,必须修改docker0的网卡配置,操作如下 1.查看网卡docker0的默认地址 ...