Codeforces Global Round 26 A~C2
惹啊啊啊啊,这场做得我发昏,最近总感觉不在状态,但还是再在冲击1600-1800的题目.
A. Strange Splitting
---------------------------------题解---------------------------------------------------
给你一个数组,让你自己构造一个RB字符串让R位置的数组中的数字的最大值-最小值不等于B位置的数组中的数字的最大值-最小值。
已知给定数组按升序排列,我们先遍历一遍字符串,如果全部相同的话则输出NO 因为差值都是0.
否则我们就让第二个为 R 这样R数组中数字max-min=0 然后其他的都是B 这样B数组的max-min必然不是0
点击查看代码
#include<bits/stdc++.h>
using namespace std;
const int N=2e5+10;
int a[N];
int main()
{
int t;
cin>>t;
while(t--)
{
int n;
cin>>n;
int q=0;
for(int i=1;i<=n;i++) cin>>a[i];
for(int i=2;i<=n;i++)
{
if(a[i]!=a[1])q=1;
}
if(q==0) cout<<"NO"<<endl;
else
{ cout<<"YES"<<endl;
for(int i=1;i<=n;i++)
{
if(i==2) cout<<"R";
else cout<<"B";
}
cout<<endl;
}
}
}
B. Large Addition
----------------------------------------题解-----------------------------------
这题我们要关注那些数不能被相同位数的数字凑出 比如 末尾为9的数字就不行 因为9 只能是一对末尾为 (4,5,(3,6),(2,7)--等数字凑出不符合题意
其次数字的开头必须是1 因为如果是1以上的数字 结合必须用相同的位数凑出的条件 比如2 开头就必须是 (1,1) 也无法符合条件 如果是比如1337这个四位数 只能由两个三位数进位而来
又比如 2337这个四位数 是由两个开头为1的数字相加而来不符合条件.
在遍历除了开头和结尾之外的数字 如果有0则不能符合条件 因为如果有0则说明她下面的那一位没有完成相加大于等于10这个进位条件 那他们就必然会有一个<5 (这里可能很多同学觉得有问题建议自己去找几个数字试一下)。
点击查看代码
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
int main()
{
int t;
cin>>t;
while(t--)
{
string a;
cin>>a;
int jud=1;
ll n=a.size();
if(a[n-1]=='9') jud=0;
if(a[0]!='1') jud=0;
for(ll i=1;i<n-1;i++)
{
if(a[i]=='0') jud=0;
}
if(jud==1) cout<<"YES"<<endl;
else cout<<"NO"<<endl;
}
}
C1. Magnitude (Easy Version)
----------------------------------------题解------------------------------
有分析知道,2操作我们应该就需要用一次就够了,因为我们会通过一次2操作让他从负数变成一个较大的数,然后在不断相加,那么2操作什么时候收益最高呢,就是在他前缀和是极小值(切
是负数)的时候(注意这个理论我们下面的hard版本要用---与easy版本关系不大) 对于这个easy版本,我们只需要维护一个最大值并且同时保留一个不断采用1操作并且在当前尝试使用2操
作的值与最大值相比较就可以了,请结合代码理解
点击查看代码
#include<bits/stdc++.h>
using namespace std;
const int N=2e5+10;
typedef long long ll;
ll a[N];
int main()
{
int t;
cin>>t;
while(t--)
{
ll n;
cin>>n;
for(ll i=1;i<=n;i++)cin>>a[i];
ll mx=0,mn=0;
for(ll i=1; i<=n; ++i)
{
mx+=a[i],mn+=a[i];
mx=max(mx,-mn);
}
cout<<mx<<endl;
}
}
/*
5
-1 0 -1 1 1
*/
C2. Magnitude (Hard Version)
能看到这里的都是糕手了,我会简化语言,主要分享思路。
----------------------------------------------------题解----------------------------------------------
这题我们是要找1,2操作都可以使用的部分
我们先处理简单的部分,假如说这个数组内全都是正数,那么我们是不是不论采用1,2操作都完全没区别所以假如说又n个数字,我们的答案就是2^n%Mod(以下把取模省略掉,自己做的时候别忘记)
还记得我们的1理论吗,我们要在前缀和最小的时候使用2操作,我们取完最小值之后,说明后面的操作不论是正数是负数,采用1,2操作都不会受到影响了,因为后面的所有操作的数字加起来一定是>=0的 所以我们用1,2都无所谓,这是2^(n-i)i是前缀和最小值所在的位置。 但是在凑出这个前缀和最小值的过程中 前缀和数组中的有些b[i]是大于0的,面对这些大于0的时候我们用1,2操作也都可以,因此答案为2(n-i)*2r(r是前缀和数组中大于0的个数)
点击查看代码
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
int main()
{
int t;
cin>>t;
while(t--)
{
string a;
cin>>a;
int jud=1;
ll n=a.size();
if(a[n-1]=='9') jud=0;
if(a[0]!='1') jud=0;
for(ll i=1;i<n-1;i++)
{
if(a[i]=='0') jud=0;
}
if(jud==1) cout<<"YES"<<endl;
else cout<<"NO"<<endl;
}
}
**/////////////////keep hard ,be the best///////////////////////////////////**
Codeforces Global Round 26 A~C2的更多相关文章
- Codeforces Global Round 11 个人题解(B题)
Codeforces Global Round 11 1427A. Avoiding Zero 题目链接:click here 待补 1427B. Chess Cheater 题目链接:click h ...
- CodeForces Global Round 1
CodeForces Global Round 1 CF新的比赛呢(虽然没啥区别)!这种报名的人多的比赛涨分是真的快.... 所以就写下题解吧. A. Parity 太简单了,随便模拟一下就完了. B ...
- Codeforces Global Round 1 - D. Jongmah(动态规划)
Problem Codeforces Global Round 1 - D. Jongmah Time Limit: 3000 mSec Problem Description Input Out ...
- Codeforces Global Round 2 题解
Codeforces Global Round 2 题目链接:https://codeforces.com/contest/1119 A. Ilya and a Colorful Walk 题意: 给 ...
- Codeforces Global Round 1 (A-E题解)
Codeforces Global Round 1 题目链接:https://codeforces.com/contest/1110 A. Parity 题意: 给出{ak},b,k,判断a1*b^( ...
- Codeforces Global Round 3
Codeforces Global Round 3 A. Another One Bites The Dust 有若干个a,有若干个b,有若干个ab.你现在要把这些串拼成一个串,使得任意两个相邻的位置 ...
- Codeforces Global Round 1 (CF1110) (未完结,只有 A-F)
Codeforces Global Round 1 (CF1110) 继续补题.因为看见同学打了这场,而且涨分还不错,所以觉得这套题目可能会比较有意思. 因为下午要开学了,所以恐怕暂时不能把这套题目补 ...
- 【手抖康复训练1 】Codeforces Global Round 6
[手抖康复训练1 ]Codeforces Global Round 6 总结:不想复习随意打的一场,比赛开始就是熟悉的N分钟进不去时间,2333,太久没写题的后果就是:A 题手抖过不了样例 B题秒出思 ...
- Codeforces Global Round 17
Codeforces Global Round 17 A. Anti Light's Cell Guessing 坑点:\(n=1,m=1\) 时答案为 \(0\) . 其他情况:当 \(n=1\) ...
- 【Codeforces Round 1110】Codeforces Global Round 1
Codeforces Round 1110 这场比赛只做了\(A\).\(B\).\(C\),排名\(905\),不好. 主要的问题在\(D\)题上,有\(505\)人做出,但我没做出来. 考虑的时候 ...
随机推荐
- 在线自动加字幕!超快完成Pr的字幕制作!
在线自动加字幕!超快完成Pr的字幕制作! https://www.bilibili.com/video/BV1T441167eX/?spm_id_from=333.788.videocard.3 ht ...
- 开发环境需要同时安装2个nodejs版本
由于同时有vue2和vue3的项目开发情况,vue2项目的nodejs版本是12,vue3项目在node12版本下运行不了,要求最低14版本,因此要用nvm同时安装和控制2个版本. 安装步骤: 1.卸 ...
- C#TMS系统学习(ShippingNotice页面)
C#TMS系统代码-业务页面ShippingNotice学习 学一个业务页面,ok,领导开完会就被裁掉了,很突然啊,他收拾东西的时候我还以为他要旅游提前请假了,还在寻思为什么回家连自己买的几箱饮料都要 ...
- 数据库—SQL语言学习
文章目录 SQL 数据类型 重要的关键字 定义数据库 数据库的文件 table创建与删除 表的定义 表的alter 表的删除 视图 定义视图 删除视图 更新视图 插入视图 视图总结 索引 SQL单表查 ...
- (二)Redis 数据类型与结构
1.值的数据类型 Redis "快"取决于两方面,一方面,它是内存数据库,另一方面,则是高效的数据结构.Redis 键值对中值的数据类型,也就是数据的保存形式有5种:String( ...
- C#应用的用户配置窗体方案 - 开源研究系列文章
这次继续整理以前的代码.本着软件模块化的原理,这次笔者对软件中的用户配置窗体进行剥离出来,单独的放在一个Dll类库里进行操作,这样在其它应用程序里也能够快速的复用该类库,达到了快速开发软件的效果. 笔 ...
- EndNote里参考文献的期刊名显示错误怎么办?
本文介绍EndNote文献管理软件导入文献引用时,期刊名称带有%J前缀从而不能正常显示的解决方法. 前期的文章中,我们多次介绍了文献管理软件EndNote的具体使用方法与技巧.而在使用EndN ...
- FastJson转Java对像字段不区分大小写
昨天遇到参数key大小写不一致导致校验签名失败的问题,查了很长时间才找到原因.看了一下FastJson源码,发现JSON.toObject中转换成对象的时候会忽略大小写. 所以,当使用了JSON.to ...
- 震惊!docker镜像还有这些知识你都知道吗
震惊!docker镜像还有这些知识你都知道吗? 镜像搜索 语法 [root@hmm docker-hello]# docker search -h Flag shorthand -h has been ...
- nodejs koa框架下载和导入excel
ac.js const service = require("../service/model.service"); const urlencode = require(" ...