Codeforces Round #726 (Div.2) A-E1 题解
A. Arithmetic Array
题目大意:一串数,求添加多少个非负整数后平均值为1
代码:
//CF726A
#include<bits/stdc++.h>
using namespace std;
#define IOS ios::sync_with_stdio(0),cin.tie(0),cout.tie(0)
typedef long long ll;
#define INF 0x3f3f3f3f
const double EPS = 1e-18;
const int MOD = 1e9 + 7;
const int maxn = 1e5 + 1;
int T, N;
void solve()
{
int num;
int sum = 0;
for (int i = 0; i < N; i++)
{
cin >> num;
sum += num;
}
if (sum == N)
cout << 0 << endl;
else if (sum < N)
cout << 1 << endl;
else
cout << sum - N << endl;
}
int main()
{
IOS;
cin >> T;
while (T--)
{
cin >> N;
solve();
}
return 0;
}
B. Bad Boy
题目大意:一个NxM的区域,一个人在(i,j),只能向上下左右移动,区域内有两个球,求球的位置使得这个人拿回两个球后回到起始位置的路程最长。
思路:放在区域的对角就一定最远。
代码:
//CF726B
#include<bits/stdc++.h>
using namespace std;
#define IOS ios::sync_with_stdio(0),cin.tie(0),cout.tie(0)
typedef long long ll;
#define INF 0x3f3f3f3f
const double EPS = 1e-18;
const int MOD = 1e9 + 7;
const int maxn = 1e5 + 1;
int T, N, M, i, j;
void solve()
{
cout << 1 << ' ' << 1 << ' ' << N << ' ' << M << ' ' << endl;
}
int main()
{
IOS;
cin >> T;
while (T--)
{
cin >> N >> M >> i >> j;
solve();
}
return 0;
}
C. Challenging Cliffs
题目大意:一个n个数的序列h,相差最小的两个数必须放在一头一尾,给出一个序列,使得满足h[i]<=h[i+1]的i最多。
思路:排序,然后找出相差最小的两个数h[i],h[j](j=i+1)放在一头一尾,之后在二者之间先输出大于h[j]的数,再输出小于h[i]的数即可,这样只有1处会不满足,所以满足条件的i的个数为n-2。
代码:
//CF726C
#include<bits/stdc++.h>
using namespace std;
#define IOS ios::sync_with_stdio(0),cin.tie(0),cout.tie(0)
typedef long long ll;
#define INF 0x3f3f3f3f
const double EPS = 1e-18;
const int MOD = 1e9 + 7;
const int maxn = 2e5 + 10;
int T, N, h[maxn];
void solve()
{
sort(h, h + N);
int si = -1, ti = -1;
int s, t, dmin = INF;
for (int i = 1; i < N; i++)
{
if (h[i] - h[i - 1] < dmin)
{
dmin = h[i] - h[i - 1];
s = h[i - 1];
t = h[i];
si = i - 1;
ti = i;
}
}
cout << s << ' ';
for (int i = ti + 1; i < N; i++)
cout << h[i] << ' ';
for (int i = 0; i < si; i++)
cout << h[i] << ' ';
cout << t << endl;
}
int main()
{
IOS;
cin >> T;
while (T--)
{
cin >> N;
for (int i = 0; i < N; i++)
cin >> h[i];
solve();
}
return 0;
}
D. Deleting Divisors
题目大意:Alice和Bob玩游戏。Alice先手,一开始有一个数字N,每次可以让N减去除N与1以外的约数,如果无法操作则判负。
思路:显然当N转化为质数的时候就会输,过程中N总共会有3种情况:
1) 奇数
2)偶数但不是2的幂
3) 2的幂
先考虑N为奇数的情况,此时N的所有约数也都为奇数,所以在减去一个约数之后N就变为了偶数,而且设N=a*b,减去a之后为a(b-1),a仍是奇数,所以此时的N是虽然是偶数但不是2的幂,所以N有奇约数,即第一种情况只能转化为第二种情况。而第二种情况只要拿掉一个约数就可以回到情况1。又因为除了2之外的质数全部都是奇数,所以当N为奇数时,先手必败,而对称地,当N为偶数但不是2的幂时,后手必败。
而对于第三种情况,设N=2^k,能够减去的约数只能是2^m(m<k),移去后N变为2^m(2^(k-m)-1)
因为如果操作后转化为情况二就自己就必败了,所以只能让N继续转化为情况三,也就是只能移去约数2^(k-1),让N=N/2。因为2^1为质数,所以当N为2的奇数次幂时,先手必败,为2的偶数次幂时,后手必败。
代码:
//CF726D
#include<bits/stdc++.h>
using namespace std;
#define IOS ios::sync_with_stdio(0),cin.tie(0),cout.tie(0)
typedef long long ll;
#define A "Alice"
#define B "Bob"
#define INF 0x3f3f3f3f
const double EPS = 1e-18;
const int MOD = 1e9 + 7;
const int maxn = 1e9 + 10;
int T, N;
void solve()
{
if (N % 2)
cout << B << endl;
else
{
int x = 0;
while (!(N % 2) && N >= 2)
{
N /= 2;
x++;
}
if (N != 1)
cout << A << endl;
else
{
if (x % 2)
cout << B << endl;
else
cout << A << endl;
}
}
}
int main()
{
IOS;
cin >> T;
while (T--)
{
cin >> N;
solve();
}
return 0;
}
E1. Erase and Extend (Easy Version)
题目大意:有一个长为N的字符串,有两种操作:1)将字符串复制一份接在后面成为一个新的字符串,2)删去字符串末尾的字符,以上操作不限次数,求若干次操作后生成的字典序最小的长度为K的字符串。
思路:因为N,K比较小,所以可以遍历初始字符串的所有前缀。不断执行操作1,直到长度>=K,之后再进行若干次操作2,将每个前缀如此操作后所得的字符串作比较,字典序最小的就是答案了。
因为对于每个前缀,如果说在若干次操作1)之间差入几次操作2)所得的字符串的字典序会更小,那么就说明该前缀的某一前缀字典序小于其某一等长后缀。那么就显然对于初始串的一个更短的前缀值行之前的操作要比这种情况还要更优,所以尽管对于每个前缀所得字符串不是最优的,但是遍历所有前缀之后不会错过最优解。
代码:
//CF-726.E1
#include<bits/stdc++.h>
using namespace std;
#define IOS ios::sync_with_stdio(0),cin.tie(0),cout.tie(0)
typedef long long ll;
#define INF 0x3f3f3f3f
const double EPS = 1e-18;
const int MOD = 1e9 + 7;
const int maxn = 1e5 + 1;
int N, K;
string s;
string ans;
void dfs(int k, string str)
{
if (str.size() > k)
{
if (ans.empty())
ans = str.substr(0, k);
else
ans = min(ans, str.substr(0, k));
return;
}
dfs(k, str + str);
}
void solve()
{
for (int i = N; i > 0; i--)//for each prefix
dfs(K, s.substr(0, i));
cout << ans << endl;
}
int main()
{
IOS;
cin >> N >> K >> s;
solve();
return 0;
}
Codeforces Round #726 (Div.2) A-E1 题解的更多相关文章
- Codeforces Round #612 (Div. 2) 前四题题解
这场比赛的出题人挺有意思,全部magic成了青色. 还有题目中的图片特别有趣. 晚上没打,开virtual contest打的,就会前三道,我太菜了. 最后看着题解补了第四道. 比赛传送门 A. An ...
- Codeforces Round #198 (Div. 2)A,B题解
Codeforces Round #198 (Div. 2) 昨天看到奋斗群的群赛,好奇的去做了一下, 大概花了3个小时Ak,我大概可以退役了吧 那下面来稍微总结一下 A. The Wall Iahu ...
- Codeforces Round #672 (Div. 2) A - C1题解
[Codeforces Round #672 (Div. 2) A - C1 ] 题目链接# A. Cubes Sorting 思路: " If Wheatley needs more th ...
- Codeforces Round #614 (Div. 2) A-E简要题解
链接:https://codeforces.com/contest/1293 A. ConneR and the A.R.C. Markland-N 题意:略 思路:上下枚举1000次扫一遍,比较一下 ...
- Codeforces Round #610 (Div. 2) A-E简要题解
contest链接: https://codeforces.com/contest/1282 A. Temporarily unavailable 题意: 给一个区间L,R通有网络,有个点x,在x+r ...
- Codeforces Round #611 (Div. 3) A-F简要题解
contest链接:https://codeforces.com/contest/1283 A. Minutes Before the New Year 题意:给一个当前时间,输出离第二天差多少分钟 ...
- Codeforces Round #499 (Div. 2) D. Rocket题解
题目: http://codeforces.com/contest/1011/problem/D This is an interactive problem. Natasha is going to ...
- 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 ...
- 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 ...
随机推荐
- Vue3 框架基础随笔 (一)
VUE框架基础部分随笔 Vue (读音 /vjuː/,类似于 view) 是一套用于构建用户界面的渐进式框架. Vue可以使用简单的代码实现一个单页面应用. 基本格式 Vue通过模板语法来声明式的将数 ...
- 搭建sublime.txt环境结合使用python
{ "cmd": ["python3", "-u", "$file"] }
- Django class meta
class Main(models.Model): img = models.CharField(max_length=200) # 图片 name = models.CharField(max_le ...
- AT2644 [ARC076C] Connected?
可以发现这个问题是存在边界的,那么我们可以先放宽一下条件思考一下没有边界的情况. 通过手玩可以发现,若不存在边界总是可以完成这个任务的. 因为两条曲线之间不存在交点,那么每次我们可以从空隙穿过一条直线 ...
- js注释和数据类型转换
单行注释 用来描述下面一个或多行代码的作用 // 这是一个变量var name = 'hm'; 多行注释 用来注释多条代码 /*var age = 18;var name = 'zs';console ...
- C#中的字符串拼接@,$
转载自:https://blog.csdn.net/qq_40666620/article/details/101695138 一:@ @的意思是以@标注的字符出,其中所有的符号均为字符串符号,没有什 ...
- 需求: 使用LinkedList存储一副扑克牌,然后实现洗牌功能。
import java.util.LinkedList; import java.util.Random; /* 需求: 使用LinkedList存储一副扑克牌,然后实现洗牌功能. */ //扑克类 ...
- JWT+ASP.NET Core集成方案
JWT JSON Web Token 经过数字签名后,无法伪造,一个能够在各方之间安全的传输JSON对象的开放标准(RFC 7519) 参考前文 [翻译]Introduction to JSON We ...
- Apache——配置与应用
Apache配置与应用 1.概述 2.httpd服务支持的虚拟主机类型 3.构建虚拟Web主机 4.构建Web虚拟目录与用户授权限制 5.日志分割 6.AWStats分析系统 1.概述: 虚拟web主 ...
- Exception in thread "main" java.lang.UnsupportedClassVersionError: org/apache/zeppelin/server/ZeppelinServer : Unsupported major.minor version 52.0
在启动Zeppelin时遇到了该问题: [root@quickstart bin]# ./zeppelin-daemon.sh restart Please specify HADOOP_CONF_D ...