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)个人题解的更多相关文章

  1. Educational Codeforces Round 92 (Rated for Div. 2) B、C题解

    TAT 第一场codeforces B. Array Walk #暴力 #贪心 题目链接 题意 有\(a1, a2, ..., an\) 个格子(每个格子有各自分数),最初为1号格(初始分数为\(a1 ...

  2. Educational Codeforces Round 61 (Rated for Div. 2) D,F题解

    D. Stressful Training 题目链接:https://codeforces.com/contest/1132/problem/D 题意: 有n台电脑,每台电脑都有初始电量ai,也有一个 ...

  3. Educational Codeforces Round 76 (Rated for Div. 2)E(dp||贪心||题解写法)

    题:https://codeforces.com/contest/1257/problem/E 题意:给定3个数组,可行操作:每个数都可以跳到另外俩个数组中去,实行多步操作后使三个数组拼接起来形成升序 ...

  4. 【Educational Codeforces Round 38 (Rated for Div. 2)】 Problem A-D 题解

    [比赛链接] 点击打开链接 [题解] Problem A Word Correction[字符串] 不用多说了吧,字符串的基本操作 Problem B  Run for your prize[贪心] ...

  5. Educational Codeforces Round 96 (Rated for Div. 2) E. String Reversal 题解(思维+逆序对)

    题目链接 题目大意 给你一个长度为n的字符串,可以交换相邻两个元素,使得这个字符串翻转,求最少多少种次数改变 题目思路 如果要求数组排序所需要的冒泡次数,那其实就是逆序对 这个也差不多,但是如果是相同 ...

  6. 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 ...

  7. 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 ...

  8. Educational Codeforces Round 43 (Rated for Div. 2)

    Educational Codeforces Round 43 (Rated for Div. 2) https://codeforces.com/contest/976 A #include< ...

  9. Educational Codeforces Round 35 (Rated for Div. 2)

    Educational Codeforces Round 35 (Rated for Div. 2) https://codeforces.com/contest/911 A 模拟 #include& ...

  10. 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 ...

随机推荐

  1. Go笔记(4)-流程控制

    5.Go语言流程控制 程序流程的控制结构一般有三种,顺序结构,选择结构,循环结构 (1)选择结构 if语句 if流程控制与其他语言的if流程控制基本相同 package main import &qu ...

  2. .net下优秀的日志框架Serilog,你用上了吗?强烈推荐

    在 .NET 开发中,Serilog 是一款广受欢迎的日志库,它提供了强大的日志记录功能,具有丰富的特性和高度的可扩展性.Serilog 的优秀之处包括: 可扩展性: Serilog 可以轻松扩展以满 ...

  3. java-导出pdf

    前言:   纯代码画pdf格式 <!-- iText PDF --> <dependency> <groupId>com.itextpdf</groupId& ...

  4. SpringCore完整学习教程5,入门级别

    本章从第6章开始 6. JSON Spring Boot提供了三个JSON映射库的集成: Gson Jackson JSON-B Jackson是首选的和默认的库. 6.1. Jackson 为Jac ...

  5. 解析$nextTick魔力,为啥大家都爱它?

    1.为什么需要使用$nextTick? 首先我们来看看官方对于$nextTick的定义: 在下次 DOM 更新循环结束之后执行延迟回调.在修改数据之后立即使用这个方法,获取更新后的 DOM. 由于vu ...

  6. vmware虚拟机 linux 本地yum源,网卡配置ens33,防火墙selinux

    1.挂载镜像文件,CentOS-7-x86_64-DVD-1804.iso,并且要处于连接状态 #光盘挂载至/mntmount /dev/sr0 /mnt #备份yum源文件cd /etc/yum.r ...

  7. Scrapy集成selenium-案例-淘宝首页推荐商品获取

    scrapy特性就是效率高,异步,如果非要集成selenium实际上意义不是特别大....因为selenium慢.... 案例:淘宝首页推荐商品的标题获取 爬虫类 toabao.py import s ...

  8. 在arm架构的银河麒麟系统部署Redis

    以下是在arm架构的银河麒麟系统上部署Redis的详细步骤: 1. 创建文件夹 首先,在合适的位置创建必要的文件夹.在本例中,我们将创建/opt/redis和/usr/src/redis两个文件夹. ...

  9. Spring 多线程的事务处理

    问题起因 Spring 的 JDBC 相关的依赖库已经提供了对 JDBC 类事务处理的统一解决方案,在正常情况下,我们只需要在需要添加事务的业务处理方法上加上 @Transactional 注解即可开 ...

  10. 斯坦福课程 UE4 C++ ActionRoguelike游戏实例教程 01.基础AI与行为树

    斯坦福课程 UE4 C++ ActionRoguelike游戏实例教程 0.绪论 前言&摘要 本篇文章是基于斯坦福UE4 C++课程的学习记录.因为B站用户surkea由于学业原因,暂停了课程 ...