Educational Codeforces Round 99 (Rated for Div. 2) (A ~ F)个人题解
Educational Codeforces Round 99 (Rated for Div. 2)
A. Strange Functions
读懂题即可(或者快速看一下样例解释),直接输出字符串长度即可。
void solve() {
string s;
cin >> s;
cout << s.length() << endl;
}
B. Jumps
这是一个数轴移动问题,按题意推导一下就好
void solve() {
int x; cin >> x;
int cnt = 0;
while (cnt * (cnt + 1) < (x << 1)) cnt++;
if (cnt * (cnt + 1) / 2 == x + 1) cnt++;
cout << cnt << endl;
}
C. Ping-pong
题意是Alice 和 Bob 开始玩击球游戏,但他们只有 x 和 y 个体力,每次发球和击回都要消耗一点体力,问怎么应对才能使两方的赢数最大
根据样例解释,其实对Bob而言只要我不回第一球,那么后面都会是Bob赢。那么就很简单了,次数为 \(x - 1, y\)
void solve() {
int x, y;
cin >> x >> y;
cout << x - 1 << " " << y << endl;
}
D. Sequence and Swaps
这道题一开始想简单了,正确思路是先判断是否已经排序好了,如果是的话直接输出0,不然把x插入每个位置进行尝试,即计算逆序,每次都进行最小值判断。
AC代码 ↓
void solve() {
int n, x;
cin >> n >> x;
vector<int> a(n);
for (int i = 0; i < n; ++i)
cin >> a[i];
int ans = n + 1;
if (is_sorted(a.begin(), a.end())){//STL函数,判断是否有序
cout << 0 << endl;
return;
}
for (int i = 0; i < n; ++i) {
vector<int> b(a);
b[i] = x;
sort(b.begin(), b.end());
int cur = x, cnt = 0;
bool f = true;
for (int j = 0; j < n; ++j) {
if (a[j] != b[j]) {
++cnt;
if (cur == b[j] && b[j] < a[j])
cur = a[j];
else
f = false;
}
}
if (f)
ans = min(ans, cnt);
}
if (ans > n)
ans = -1;
cout << ans << "\n";
}
E. Four Points

直接去写的话感觉很麻烦,这里思路借鉴了rank2的大神的代码:转化为复数处理。
对标样例模拟就清楚了。
void solve() {
ll ans = 1e18;
pair<int, int> p[4];
for (int i = 0; i < 4; ++i)
cin >> p[i].first >> p[i].second;
sort(p, p + 4);
do {
vector<int> cand{0};
for (int i = 0; i < 2; ++i)
for (int j = 0; j < 2; ++j) {
cand.push_back(p[2 + j].first - p[i].first);
cand.push_back(p[2 * j + 1].second - p[2 * i].second);
}
for (auto d : cand) {
if (d < 0)
continue;
ll res = 0;
int x[4], y[4];
for (int i = 0; i < 4; ++i)
tie(x[i], y[i]) = p[i]; //转化为复数处理
x[2] -= d, x[3] -= d;
y[1] -= d, y[3] -= d;
sort(x, x + 4), sort(y, y + 4);
for (int i = 0; i < 4; ++i) {
res += abs(x[i] - x[1]);
res += abs(y[i] - y[1]);
}
ans = min(res, ans);
}
} while (next_permutation(p, p + 4));
cout << ans << endl;
}
F. String and Operations
贴一下dalao代码作为学习
Code
void update(std::string& a, const std::string& b) {
if (a.empty() || a > b)
a = b;
}
void solve() {
int n, k;
std::cin >> n >> k;
std::string a, b;
std::cin >> a;
b = a;
for (int i = 0; i < n; ++i) {
if (b[i] == 'a' + k - 1)
b[i] = 'a';
else if (b[i] != 'a')
--b[i];
}
std::string dp[2][2];
dp[0][0] = a;
int cur = 0;
for (int i = 0; i < n; ++i) {
cur ^= 1;
dp[cur][0] = dp[cur][1] = "";
if (!dp[!cur][0].empty()) {
auto& s = dp[!cur][0];
update(dp[cur][0], s);
if (i > 0) {
std::swap(s[i], s[i - 1]);
update(dp[cur][0], s);
std::swap(s[i], s[i - 1]);
}
if (i + 1 < n) {
std::swap(s[i], s[i + 1]);
update(dp[cur][1], s);
std::swap(s[i], s[i + 1]);
}
s[i] = b[i];
update(dp[cur][0], s);
}
if (!dp[!cur][1].empty()) {
auto& s = dp[!cur][1];
update(dp[cur][0], s);
if (i > 1) {
std::swap(s[i - 1], s[i - 2]);
update(dp[cur][0], s);
std::swap(s[i - 1], s[i - 2]);
}
s[i - 1] = b[i];
update(dp[cur][0], s);
}
}
std::cout << dp[cur][0] << "\n";
}
G. Forbidden Value
最后一道题似乎是线段树 + DP ? 看完题没啥思路。。。(老菜鸡了)
Educational Codeforces Round 99 (Rated for Div. 2) (A ~ F)个人题解的更多相关文章
- Educational Codeforces Round 92 (Rated for Div. 2) B、C题解
TAT 第一场codeforces B. Array Walk #暴力 #贪心 题目链接 题意 有\(a1, a2, ..., an\) 个格子(每个格子有各自分数),最初为1号格(初始分数为\(a1 ...
- Educational Codeforces Round 61 (Rated for Div. 2) D,F题解
D. Stressful Training 题目链接:https://codeforces.com/contest/1132/problem/D 题意: 有n台电脑,每台电脑都有初始电量ai,也有一个 ...
- Educational Codeforces Round 76 (Rated for Div. 2)E(dp||贪心||题解写法)
题:https://codeforces.com/contest/1257/problem/E 题意:给定3个数组,可行操作:每个数都可以跳到另外俩个数组中去,实行多步操作后使三个数组拼接起来形成升序 ...
- 【Educational Codeforces Round 38 (Rated for Div. 2)】 Problem A-D 题解
[比赛链接] 点击打开链接 [题解] Problem A Word Correction[字符串] 不用多说了吧,字符串的基本操作 Problem B Run for your prize[贪心] ...
- Educational Codeforces Round 96 (Rated for Div. 2) E. String Reversal 题解(思维+逆序对)
题目链接 题目大意 给你一个长度为n的字符串,可以交换相邻两个元素,使得这个字符串翻转,求最少多少种次数改变 题目思路 如果要求数组排序所需要的冒泡次数,那其实就是逆序对 这个也差不多,但是如果是相同 ...
- Educational Codeforces Round 60 (Rated for Div. 2) - C. Magic Ship
Problem Educational Codeforces Round 60 (Rated for Div. 2) - C. Magic Ship Time Limit: 2000 mSec P ...
- Educational Codeforces Round 60 (Rated for Div. 2) - D. Magic Gems(动态规划+矩阵快速幂)
Problem Educational Codeforces Round 60 (Rated for Div. 2) - D. Magic Gems Time Limit: 3000 mSec P ...
- Educational Codeforces Round 43 (Rated for Div. 2)
Educational Codeforces Round 43 (Rated for Div. 2) https://codeforces.com/contest/976 A #include< ...
- Educational Codeforces Round 35 (Rated for Div. 2)
Educational Codeforces Round 35 (Rated for Div. 2) https://codeforces.com/contest/911 A 模拟 #include& ...
- Codeforces Educational Codeforces Round 44 (Rated for Div. 2) F. Isomorphic Strings
Codeforces Educational Codeforces Round 44 (Rated for Div. 2) F. Isomorphic Strings 题目连接: http://cod ...
随机推荐
- LeetCode-Java:122. 买卖股票的最佳时机Ⅱ
题目 给你一个整数数组 prices ,其中 prices[i] 表示某支股票第 i 天的价格. 在每一天,你可以决定是否购买和/或出售股票.你在任何时候 最多 只能持有 一股 股票.你也可以先购买, ...
- 文心一言 VS 讯飞星火 VS chatgpt (149)-- 算法导论12.2 4题
五.用go语言,证明:如果一棵二叉搜索树中的一个结点有两个孩子,那么它的后继没有左孩子,它的前驱没有右孩子. 灵捷3.5 . 文心一言: 为了证明这个性质,我们首先需要明确二叉搜索树(BST)的定义和 ...
- WPF应用框架中工作流模块的介绍
在前面的随笔,我对我们开发的审批工作流做了不少的介绍,其中有包括WInform的.Vue+Element.Bootstrap Asp.net的,在各个框架上,我们都尽量争取界面能够一致化,以便客户能够 ...
- JSON多层嵌套复杂结构数据扁平化处理转为行列数据
背景 公司的中台产品,需要对外部API接口返回的JSON数据进行采集入湖,有时候外部API接口返回的JSON数据层级嵌套比较深,举个栗子: 上述的JSON数据中,最外层为请求返回对象,data里面包含 ...
- RocksDB 在 vivo 消息推送系统中的实践
作者:vivo 互联网服务器团队 - Zeng Luobin 本文主要介绍了 RocksDB 的基础原理,并阐述了 RocksDB 在vivo消息推送系统中的一些实践,通过分享一些对 RocksDB ...
- HDU-3591 混合背包
The trouble of Xiaoqian Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/ ...
- 组合式api-ref引用子组件、dom元素, defineExpose的使用
和vue2一样,我们有时候希望父组件能够调用子组件中的方法.属性.那么就要用到ref. 然后你会发现,根本调用不了子组件中的方法"sonSayHi",如下图: 原因: 使用
- MinIO客户端之share
MinIO提供了一个命令行程序mc用于协助用户完成日常的维护.管理类工作. 官方资料 mc share mc share download mc share upload 生成下载对象的URL,指定对 ...
- 【OpenCV】在MacOS上源码编译OpenCV
前言 在做视觉任务时,我们经常会用到开源视觉库OpenCV,OpenCV是一个基于Apache2.0许可(开源)发行的跨平台计算机视觉和机器学习软件库,它具有C++,Python,Java和MATLA ...
- Python——第二章:查找和判断
查找.find() s = "你好啊. 我叫周润发" ret = s.find("周润发") # 返回是7,代表该字符串出现在7号位置,从0开始计数 print ...