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 ...
随机推荐
- Macbook磁盘系统结构/文件/目录介绍分析
1. 系统磁盘根目录详解: 1.1 磁盘根目录结构 / (根目录)|-- Applications # 存放应用程序|-- Users # 存放用户文件和设置|-- cores # 存放核心转储文件, ...
- Flink State 状态原理解析
一.Flink State 概念 State 用于记录 Flink 应用在运行过程中,算子的中间计算结果或者元数据信息.运行中的 Flink 应用如果需要上次计算结果进行处理的,则需要使用状态存储中间 ...
- VSCode个性化的配置
1.下载插件 Eclipse快捷键(我以前用Eclipse习惯了,大家不需要) Premitter Vetur koroFileHeader 2.修改VSCode设置 3.粘贴下面的代码 { &quo ...
- 36. 干货系列从零用Rust编写负载均衡及代理,内网穿透中内网代理的实现
wmproxy wmproxy已用Rust实现http/https代理, socks5代理, 反向代理, 静态文件服务器,四层TCP/UDP转发,七层负载均衡,内网穿透,后续将实现websocket代 ...
- Havoc C2d的初次使用
Havoc C2 简介 Havoc是一款现代化的.可扩展的后渗透命令控制框架 当前的Havoc版本还处于早期开发版,随着框架的不断成熟,可能会对Havoc的API和核心结构进行大量更改 以下的配置部分 ...
- Java 并发编程(二 )Thread
线程状态 线程一般的状态转换图如下: 在线程生命周期中存在的状态解释如下: New(初始化)状态 此时线程刚刚被实例化,可以通过调用 start() 方法来启动这个实例化的的线程,使其状态转变成为 R ...
- 动态规划问题(六)最长公共子序列(LCS)
问题描述 给你两个字符串,要求得到这两个字符串的最长公共子序列长度. 比如:对于输入的字符串 S1 "AGGTAB" 和 S2 "GXTXAYB",它们 ...
- Base64编码:数据传输的安全使者
Base64编码是一种将二进制数据转换为可传输的文本表示形式的方法,它在全球范围内被广泛应用于网络通信.数据存储和传输等领域.本文将从多个方面介绍Base64编码的原理.应用及其在现实场景中的优势,帮 ...
- Windows10安装WSL2和Ubuntu的过程
因为在Windows10环境中安装了2个相同的包导致冲突,所以想到了通过WSL2+Docker的方式进行编程开发.因为Docker Desktop直接安装就行了,不做介绍.本文主要介绍WSL2和U ...
- 大道如青天,协程来通信,Go lang1.18入门精炼教程,由白丁入鸿儒,Go lang通道channel的使用EP14
众所周知,Go lang的作用域相对严格,数据之间的通信往往要依靠参数的传递,但如果想在多个协程任务中间做数据通信,就需要通道(channel)的参与,我们可以把数据封装成一个对象,然后把这个对象的指 ...