写在前边

链接:Codeforces Round #693 (Div. 3)

没有打,闲的没事补一下题。

A. Cards for Friends

链接:A题链接

题目大意:

给定一张\(w*h\)的卡片,每次可以切成\(\cfrac{w}{2} * h\)或者\(\cfrac{h}{2} * w\)的两张卡片,给定一个整数\(n\),问所给的大卡片是否切成至少\(n\)张卡片。

思路

一开始想的太复杂了,分情况讨论了半天还是WA,其实这题就是长和宽分别切就行,每符合题意切一次,\(res *= 2\),得到答案。

代码:

#include <iostream>

using namespace std;

int main() {
int t;
cin >> t;
while (t--) {
int w, h, n, res = 1;
cin >> w >> h >> n;
while (w % 2 == 0) {
w /= 2;
res *= 2;
}
while (h % 2 == 0) {
h /= 2;
res *= 2;
}
cout << (res >= n ? "YES" : "NO") << endl;
} return 0;
}

B. Fair Division

链接:B题链接

题目大意:

给定\(n\)个糖果,每个糖果的重量是\(1\)或者\(2\),现在将糖果平分给两人,问是否能实现两个人分得的重量相同,注意:一个糖果不能分成两半。

思路

我的思路:求其总重量,看总重量是否能被2整除,若不能整除,那么肯定为\("NO"\),若能平分,那么我们只看一个人即可,将糖果从大到小排序,然后如果能正好分给一个人,那么剩下的就是第二个人的糖果了,会多用一重循环。

代码:

#include <iostream>
#include <algorithm> using namespace std; typedef long long LL; const int N = 110;
LL w[N]; int main() {
int t, n;
cin >> t;
while (t--) {
LL sum = 0;
cin >> n;
for (int i = 0; i < n; i++) {
cin >> w[i];
sum += w[i];
}
if (sum % 2 != 0) {
puts("NO");
continue;
}
sum /= 2;
sort(w, w + n);
LL temp = 0;
for (int i = n - 1; i >= 0; i--) {
if (temp + w[i] <= sum) {
temp += w[i];
}
}
cout << (temp == sum ? "YES" : "NO") << endl;
} return 0;
}
官方的思路:直接判断,省去循环

对重量为0的糖果和重量为1的糖果分别统计个数,那么和就是\((cnt1 + cnt2 * 2)\),若和不能被2整除那肯定为\(“NO”\),若能被整除,那么分给每个人的重量就为\(sum = \cfrac{(cnt1 + cnt2*2)}{2}\), 再判断糖果是否能实现对两个人的合理分配,若\(sum \% 2 == 0\),那么说明所给的糖果可以凑出\(\cfrac{sum}{2}\)个\(2\)(想不明白可以用反证法:若所给糖果凑不出\(\cfrac{sum}{2}\)个\(2\),那么肯定所给糖果中有奇数个\(1\),那么说明\(sum \% 2 != 0\),与\(sum \% 2 == 0\)矛盾)那么就说明可以实现合理分配,如果\(sum \% 2 != 0\),那么说明在分给一人若干个\(2\)之后。会有\(1\)来补齐,因此只需要判断一下\(cnt1 != 0\)即可。

#include <iostream>

using namespace std;

int main() {
int t, n;
cin >> t;
while (t--) {
cin >> n;
int cnt1 = 0, cnt2 = 0, c;
for (int i = 0; i < n; i++) {
cin >> c;
if (c == 1) {
cnt1++;
} else {
cnt2++;
}
}
if ((cnt1 + cnt2 * 2) % 2 != 0) {
puts("NO");
} else {
int sum = (cnt1 + cnt2 * 2) / 2;
if ((sum % 2 == 0) || (sum % 2 != 0 && cnt1 != 0)) {
puts("YES");
} else {
puts("NO");
}
}
} return 0;
}

C. Long Jumps

链接:C题链接

题目大意:

给定一个数组\(a\),下标是\(i \in [1, n]\),从\(i\)跳到\(i + a[i]\)的得分是\(a[i]\),以此类推直到下标超过\(n\),例如:\(n=5\),\(a=[7,3,1,2,3]\)。

当\(i = 1\)时,\(1 + a[1] = 8\),跳出了n,因此\(score[1] = a_1 = 7\)。

当\(i = 2\)时,\(2 + a[2] = 5\),跳到了\(i = 5\),从\(5\)开始跳,\(5 + a[5] = 8\),因此\(score[2] = a_2 + a_5 = 6\)

依次类推...

求最后最大\(score_i\)

思路

一开始还是只想到了两重循环暴力,铁定超时,然后就得想怎么才能优化。

于是发现这样一个递推公式:\(score[i] = score[i + a[i]] + a[i]\),并且为了记录下\(score[i + a[i]]\),我们选择倒着枚举,这样\(score[i + a[i]]\)就被提前记录啦,最后再找一下最大值即可,于是就从\(O(n^2)\)优化成了\(O(n)\)

代码:

#include <iostream>
#include <algorithm>
#include <vector> using namespace std; const int N = 2e5 + 10;
int a[N], f[N]; int main() {
int t, n;
cin >> t;
while (t--) {
cin >> n;
for (int i = 0; i < n; i++) {
cin >> a[i];
}
vector<int> f(n + 1);
for (int i = n - 1; i >= 0; i--) {
f[i] = a[i];
int j = i + a[i];
if (j < n) {
f[i] += f[j];
}
}
cout << *max_element(f.begin(), f.end()) << endl;
}
system("pause");
return 0;
}

D. Even-Odd Game

链接:D题链接

题目大意:

\(Alice\)与\(Bob\)玩游戏,给定一个数组\(a\),\(Alice\)先手,\(Bob\)后手从里边拿牌,若\(Alice\)取到的偶数那么就加分加\(a_i\),否则不加分,\(Bob\)取到奇数加分,否则不加分,直到牌被取完,最后谁的分数高谁获胜,保证游戏是公平的且两者的取法都是最优。

思路

一个简单的博弈论问题,但是我没想出来。

可以换一种角度思考,取一个基准分,\(Alice\)取到偶数那么基准分加分,\(Bob\)取到奇数相当于基准分减分减分,因此这样看来,\(Alice\)想让它越大越好,\(Bob\)想让它越小越好。对于\(Alice\)来说,她肯定想拿的数越大越好,如果是大偶数那么直接加分了,如果是拿大的奇数那么\(Bob\)就拿不到,因此对于\(Bob\)也是如此,因此对于两者来说都是拿的分越大越好。

还有见到一个数\(1e9\)这种,一定要记得开\(long long\)

代码:

#include <iostream>
#include <algorithm> using namespace std; typedef long long ll; const int N = 2E5 + 10;
ll a[N]; bool cmp(ll a, ll b) {
return a > b;
} int main() {
int t, n;
cin >> t;
while (t--) {
cin >> n;
for (int i = 1; i <= n; i++) {
cin >> a[i];
}
ll res = 0;
sort(a + 1, a + n + 1, cmp);
for (int i = 1; i <= n; i++) {
if (i % 2 == 1) {//Alice取
if (a[i] % 2 == 0) {
res += a[i];
}
} else { //Bob取
if (a[i] % 2 == 1) {
res -= a[i];
}
}
}
if (res == 0) {
puts("Tie");
} else if (res > 0) {
puts("Alice");
} else {
puts("Bob");
}
} return 0;
}

E. Correct Placement

链接:E题链接

题目大意:

\(n\)个人拍照,矮的并且瘦得会站在前边,比如有\(i\)、\(j\)两位同学,\(h_i\)、\(w_i\)、\(h_j\)、\(w_j\)分别是两位同学的身高,与身体宽度,若\((h_j<h_i\quad and\quad w_j<w_i) \quad or \quad (h_j<w_i \quad and\quad w_j<h_i)\) 那么\(j\)同学都可以站在\(i\)同学的前面,对于每一位同学,输出可以站在它前边的任意一位同学的编号。

思路

看博客有个大佬的想法真的太棒了,既然身高体宽都不确定大小,而且都可以用来比较,那么我们再输入的时候直接处理一下,让\(h_i\)与\(w_i\)较大的那个作为身高即可,这样就不必再处理两遍,按照\(h_i\)从小到大排一个序列,找到\(h_i\)不同的情况下,\(w\)最小的那个(一定是在当前同学的前边找,因为排序过后后边的同学一定是不满足的),并且记录它的坐标,因此贪心一下就始终以\(w\)最小的作为答案即可,同时若遇到更小的记得更新它,还有就是要注意身高相同的情况下不得更新\(min_w\)。

代码:

#include <iostream>
#include <algorithm>
#include <tuple> using namespace std; const int N = 2e5 + 10;
int res[N]; struct node {
int index, h, w;
} a[N]; bool operator< (const node &a, const node &b) {
return tie(a.h, a.w, a.index) < tie(b.h, b.w, b.index);
} void solve() {
int n;
cin >> n;
for (int i = 1; i <= n; i++) {
a[i].index = i;
cin >> a[i].h >> a[i].w;
if (a[i].h < a[i].w) {
swap(a[i].h, a[i].w);
}
} sort(a + 1, a + n + 1);
int p = 1;
int min_idx = 0, min_w = 1e9;
for (int i = 1; i <= n; i++) {
if (i != 1 && a[i].h != a[i - 1].h) {
while (p < i) {
if (min_w > a[p].w) {
min_w = a[p].w;
min_idx = a[p].index;
}
p++;
}
}
if (min_w >= a[i].w) {
res[a[i].index] = -1;
} else {
res[a[i].index] = min_idx;
}
}
for (int i = 1; i <= n; i++) {
cout << res[i] << " ";
}
cout << endl;
} int main() {
int t;
cin >> t;
while (t--) {
solve();
} return 0;
}

Codeforces Round #693 (Div. 3) A~E 题解的更多相关文章

  1. Codeforces Round #612 (Div. 2) 前四题题解

    这场比赛的出题人挺有意思,全部magic成了青色. 还有题目中的图片特别有趣. 晚上没打,开virtual contest打的,就会前三道,我太菜了. 最后看着题解补了第四道. 比赛传送门 A. An ...

  2. Codeforces Round #198 (Div. 2)A,B题解

    Codeforces Round #198 (Div. 2) 昨天看到奋斗群的群赛,好奇的去做了一下, 大概花了3个小时Ak,我大概可以退役了吧 那下面来稍微总结一下 A. The Wall Iahu ...

  3. Codeforces Round #672 (Div. 2) A - C1题解

    [Codeforces Round #672 (Div. 2) A - C1 ] 题目链接# A. Cubes Sorting 思路: " If Wheatley needs more th ...

  4. Codeforces Round #614 (Div. 2) A-E简要题解

    链接:https://codeforces.com/contest/1293 A. ConneR and the A.R.C. Markland-N 题意:略 思路:上下枚举1000次扫一遍,比较一下 ...

  5. Codeforces Round #610 (Div. 2) A-E简要题解

    contest链接: https://codeforces.com/contest/1282 A. Temporarily unavailable 题意: 给一个区间L,R通有网络,有个点x,在x+r ...

  6. Codeforces Round #611 (Div. 3) A-F简要题解

    contest链接:https://codeforces.com/contest/1283 A. Minutes Before the New Year 题意:给一个当前时间,输出离第二天差多少分钟 ...

  7. Codeforces Round #499 (Div. 2) D. Rocket题解

    题目: http://codeforces.com/contest/1011/problem/D This is an interactive problem. Natasha is going to ...

  8. Codeforces Round #499 (Div. 2) C Fly题解

    题目 http://codeforces.com/contest/1011/problem/C Natasha is going to fly on a rocket to Mars and retu ...

  9. Codeforces Round #198 (Div. 2)C,D题解

    接着是C,D的题解 C. Tourist Problem Iahub is a big fan of tourists. He wants to become a tourist himself, s ...

  10. Codeforces Round #579 (Div. 3) 套题 题解

    A. Circle of Students      题目:https://codeforces.com/contest/1203/problem/A 题意:一堆人坐成一个环,问能否按逆时针或者顺时针 ...

随机推荐

  1. centos7.9 时间相关整理

    1.date / timedatectl 显示当前时间(秒): date / date +"%Y-%m-%d %H:%M:%S" (%Y等含义通过data --h查看) 显示当前时 ...

  2. TypeChat源码分析:基于大语言模型的定制化 AI Agent 交互规范

    TypeChat源码分析:基于大语言模型的定制化 AI Agent 交互规范 本文深入介绍了微软最近发布的 TypeChat 项目,该项目允许开发者定义大语言模型返回的响应结构.通过分析源代码,探讨了 ...

  3. 构建易于运维的 AI 训练平台:存储选型与最佳实践

    伴随着公司业务的发展,数据量持续增长,存储平台面临新的挑战:大图片的高吞吐.超分辨率场景下数千万小文件的 IOPS 问题.运维复杂等问题.除了这些技术难题,我们基础团队的人员也比较紧张,负责存储层运维 ...

  4. [k8s]使用nfs挂载pod的应用日志文件

    前言 某些特殊场景下应用日志无法通过elk.grafana等工具直接查看,需要将日志文件挂载出来再处理.本文以nfs作为远程存储,统一存放pod日志. 系统版本:CentOS 7 x86-64 宿主机 ...

  5. 三维模型OBJ格式轻量化压缩处理的数据质量提升方法分析

    三维模型OBJ格式轻量化压缩处理的数据质量提升方法分析 在三维模型的OBJ格式轻量化压缩处理过程中,除了减小文件大小和提高加载速度之外,我们也需要考虑如何提升数据质量.以下是几种常见的方法: 1.优化 ...

  6. CodeForces 1343E Weights Distributing

    题意 多组样例 给定\(n,m,a,b,c\),给定一个长度为\(m\)的数组\(p[]\),给定\(m\)条边,构成一个\(n\)个点\(m\)条边的无向图,\(Mike\)想要从\(a\)走到\( ...

  7. 「loj - 6179」Pyh 的求和

    link. 我们想要求出 \(\varphi(ij)=\varphi(i)\varphi(j)C\) 中的常数.先研究 \(i=p^a\),\(j=p^b\) 的情况,即 \(\varphi(p^{a ...

  8. Blazor Server 发起HttpPost请求,但是多参数

    一.介绍 今天突然想起之前工作上遇到的一个问题,在做Blazor 开发时后端给的一个接口请求方式是Post ,但是他需要携带多个参数,新建一个公共类又觉得麻烦,我就尝试着怎么在Post请求中携带多个参 ...

  9. RabbitMQ——RabbitMQ面试题

    文章目录 为什么使用MQ?MQ的优点 消息队列有什么优缺点?RabbitMQ有什么优缺点? 你们公司生产环境用的是什么消息中间件? Kafka.ActiveMQ.RabbitMQ.RocketMQ 有 ...

  10. [ABC310D] Peaceful Teams 题解

    Peaceful Teams 题目大意 将 \(n\) 个人分成 \(T\) 组,要求每组不能包含敌对的人,问有多少种分法. 思路分析 注意到 \(n,T\) 均很小,考虑爆搜. 注意到直接枚举会枚举 ...