#627 DIV3 题解
A.
每组给一个和个数(),每次操作可以给一个加2,求是否能使n个数相等
4
3
1 1 3
4
1 1 2 1
2
11 11
1
100
YES
NO
YES
YES
直接扫一遍,记录最大值与当前的差是否能被2整除。
#include<bits/stdc++.h>
using namespace std;
int a[120];
int main() {
//freopen("in.txt","r",stdin);
int t, n; cin >> t;
while (t--) {
cin >> n;
int Max = -1;
for (int i = 0; i < n; ++i)cin >> a[i], Max = max(Max, a[i]);
bool f = false;
for (int i = 0; i < n; ++i) {
int d = Max - a[i];
if (d % 2 == 1) {
f = true; break;
}
}
if (f)cout << "NO" << endl;
else cout << "YES" << endl;
}
}
B.
样例,每组给一个和个数(,中是否存在一个长度至少为3的子序列为回文串。
5
3
1 2 1
5
1 2 2 3 2
3
1 1 2
4
1 2 2 1
10
1 1 2 2 3 3 4 4 5 5
YES
YES
NO
YES
NO
在找到两个数相等之后,由于是子序列可以不连续,在两个数之间随便找一个数即可
#include<bits/stdc++.h>
using namespace std;
int n, t, a[5050];
int main() {
//freopen("in.txt", "r", stdin);
cin >> t; while (t--) {
cin >> n; for (int i = 1; i <= n; ++i)cin >> a[i];
bool flag = false;
//双指针思想
for (int i = 1; i < n; i++) {
for (int j = i + 1; j <= n; j++) {
if (a[i] == a[j]) {
if (j - i > 1) flag = 1;
}
}
if (flag == 1) break;
}
if (flag)cout << "YES" << endl;
else cout << "NO" << endl;
}
}
C.
题意:
给出一个字符串, 只包含两个字符‘L’,‘R’,如果为L,只能向左走,如果为R,只能向右走,问一只青蛙从最左端开始走,走到最右端一次最少跳多远。这只青蛙可以跳的距离为 [ 1,最短长度 ] 这个区间。
举例:LRLRRLL,最短跳的距离为 3
首先从 0 位置跳到 第一个 'R', 然后从第一个‘R’跳到第二个或者第三个 'R',最终跳到末尾。
在这个样例中,最短跳的距离为 3, 意味着这个青蛙可以向右跳1步,或者2步,或者3步。
解题思路:
可以将字符串两端加入R,判断两个R的最远距离即可,但注意 最短距离下限为 1 而不是 0。
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int mod = 1e9 + 7;
string s;
int main() {
int t; cin >> t;
while (t--) {
cin >> s; int len = s.length();
s[len] = 'R';
int ans = 1, j = len;
for (int i = len - 1; i >= 0; --i) {
if (s[i] == 'R')
ans = max(ans, j - i), j = i;
}
if (s[0] != 'R')
ans = max(ans, j + 1);
cout << ans << endl;
}
cin >> s;
}
D.
给一个和个数,求满足+的二元组,一共有多少对。()
5
4 8 2 6 2
4 5 4 1 3
7
要满足+的条件,直接排序,然后差值遍历过程从upper_bound找到第一个大于的数即可。
#include<bits/stdc++.h>
using namespace std;
const int maxn = 2e5 + 10;
int n; long long a[maxn], b[maxn], d[maxn], tmp[maxn];
int main() {
cin >> n;
for (int i = 1; i <= n; ++i)cin >> a[i];
for (int i = 1; i <= n; ++i)cin >> b[i], d[i] = a[i] - b[i];
sort(d + 1, d + 1 + n);
long long ans = 0;
//ai + aj > bi + bj <=> Di > -Dj (ai - bi > -(aj - bj))
for (int i = 1; i <= n; ++i) {
int index = upper_bound(d + 1 + i, d + 1 + n, -d[i]) - d;
ans += n - index + 1;//index表示为第一个大于的位置,总数要n - index + 1
}
cout << ans;
}
E.
一天有个n小时,Vova要睡到一定时间
7 24 21 23
16 17 14 20 20 11 22
3
考虑表示前次睡眠刚好用了次减1操作。记录一个关于的前缀和,舒适睡眠的条件是
同时要考虑当前的这个,是在用了一次减一操作还是没有用。
若用了一次减一操作之后的情况:
若在第次没有用的话:
当然如果,不满足,直接从转移到即可,不需要+1。
#include <bits/stdc++.h>
using namespace std;
const int maxn = 2000 + 5;
int a[maxn], dp[maxn][maxn], sum[maxn];
int main(){
int n, h, l, r;
scanf("%d %d %d %d", &n, &h, &l, &r);
for(int i = 1;i <= n;i++) {
scanf("%d", a + i);
sum[i] = sum[i - 1] + a[i];
}
for(int i = 1;i <= n;i++) {
for(int j = 0;j <= i;j++) {
if(sum[i] - j < 0) continue;
if((sum[i] - j) % h <= r && (sum[i] - j) % h >= l) {
if(j != 0) {
dp[i][j] = max(dp[i][j], max(dp[i-1][j], dp[i-1][j-1]) + 1);
} else {
dp[i][j] = max(dp[i][j], dp[i-1][j] + 1);
}
} else {
if(j != 0) {
dp[i][j] = max(dp[i-1][j], dp[i-1][j-1]);
} else {
dp[i][j] = dp[i-1][j];
}
}
}
}
int ans = 0;
for(int i = 0;i <= n;i++) {
ans = max(ans, dp[n][i]);
}
printf("%d\n", ans);
return 0;
}
F.(未做出,网摘解法)
给一颗有个点的树和一个01数组,表示号节点是黑色还是白色,0为黑,1为白,问对于每个,包含点的联通块中的最大值是多少。
9
0 1 1 1 0 0 0 0 1
1 2
1 3
3 4
3 5
2 6
4 7
6 8
5 9
2 2 2 2 2 1 1 0 2
对于一个树上节点来说,为了扩大的值,只能沿着子节点或者父节点往外扩展,用两个来考虑各自的贡献。
首先考虑子树中的贡献,是的子节点,显然只要,所以
之后考虑来自父亲方向的贡献,是的父节点,若,那么往这个方向扩展只会让变小,所以不予考虑。若,我们需要判断节点取最大值的时候,有没有把节点包含进来,若则肯定包含进来了,当把包含进来时,和在统一联通块,之前假设是>,所以
若时,没有和在同一联通块,而为了使变大,在的时候有
在写法上,显然最小的值只能是-1,因为一个黑点在不能扩展的时候没有必要再加一个黑点进来。所以小于0的情况只要-1。
#include <bits/stdc++.h>
using namespace std;
const int maxn = 2e5+5;
int a[maxn], dp[maxn];
vector<int> G[maxn];
void dfs1(int u, int fa) {
for(int i = 0;i < G[u].size();i++) {
int v = G[u][i];
if(v == fa) continue;
dfs1(v, u);
if(dp[v] >= 0) dp[u] += dp[v];
}
}
void dfs2(int u, int fa) {
for(int i = 0;i < G[u].size();i++) {
int v = G[u][i];
if(v == fa) continue;
if(dp[u] - dp[v] > 0) {
if(dp[v] != -1) dp[v] = dp[u];
else {
dp[v] += dp[u];
}
}
dfs2(v, u);
}
}
int main(){
int n = 0;
scanf("%d", &n);
for(int i = 1;i <= n;i++) {
scanf("%d", a + i);
if(a[i] == 0) {
dp[i] = -1;
} else {
dp[i] = 1;
}
}
for(int i = 1;i < n;i++) {
int u, v;
scanf("%d %d", &u, &v);
G[u].push_back(v); G[v].push_back(u);
}
dfs1(1, 0); dfs2(1, 0);
for(int i = 1;i <= n;i++) {
printf("%d%c", dp[i], i == n ? '\n' : ' ');
}
return 0;
}
#627 DIV3 题解的更多相关文章
- Codeforces Round #481 (Div. 3)
我实在是因为无聊至极来写Div3题解 感觉我主要的作用也就是翻译一下题目 第一次线上打CF的比赛,手速很重要. 这次由于所有题目都是1A,所以罚时还可以. 下面开始讲题 A.Remove Duplic ...
- CF1256(div3 java题解)
A: 题意:给定A个N元,B个一元,问是否可以凑成S元. 思路:A*i+j=S 即 A*I<=S<=A*I+B 即min(S/N,A)+B>=S: /* @author nimphy ...
- Codeforces #550 (Div3) - G.Two Merged Sequences(dp / 贪心)
Problem Codeforces #550 (Div3) - G.Two Merged Sequences Time Limit: 2000 mSec Problem Description T ...
- CodeForces 1029E div3
题目链接 第一道场上自己做出来的E题...虽然是div3,而且是原题... 当时做完ABC,D题没有思路就去怼E了,然后发现貌似原题? 事实上就是原题... 给个原题链接... [HNOI2003]消 ...
- Codeforces Round #535 (Div. 3) [codeforces div3 难度测评]
hhhh感觉我真的太久没有接触过OI了 大约是前天听到JK他们约着一起刷codeforces,假期里觉得有些颓废的我忽然也心血来潮来看看题目 今天看codeforces才知道居然有div3了,感觉应该 ...
- 题解报告:hdu 1028 Ignatius and the Princess III(母函数or计数DP)
Problem Description "Well, it seems the first problem is too easy. I will let you know how fool ...
- CodeForces Round#480 div3 第2场
这次div3比上次多一道, 也加了半小时, 说区分不出1600以上的水平.(我也不清楚). A. Remove Duplicates 题意:给你一个数组,删除这个数组中相同的元素, 并且保留右边的元素 ...
- 【CF598 Div3 F】Equalizing Two Strings
一道通篇结论的傻逼题,被 lh 随手秒了 别告诉我你不会 Div3 的题,你肯定在 fake 没看过题解,以下做法纯属口胡,应该没问题 Description https://www.luogu.or ...
- CF #575 Div3
// 比赛链接:https://codeforces.com/contest/1196 // CF 2019.7.24 // 本想Div3手速场上分,结果卡在C题,掉了不少分. // 自闭了这么久,今 ...
- codeforces 1426F,初学者也能做,div3的最难题
大家好,欢迎阅读codeforces专题. 今天选择的题目是Div3比赛的最后一题,也是最难的一道题.选这道题的主要原因是帮助大家建立信心,因为有些小伙伴给我反应说之前选择的题目有些难了,觉得自己可能 ...
随机推荐
- iOS程序生命周期流程
盛年不重来,一日难再晨.及时宜自勉,岁月不待人. iOS系统资源是有限的,合理的去配置应用程序的运行状态以及了解app的生命周期对于大多数开发者来说是很重要的一件事情!在后台进行运行时app会受到 ...
- java集合框架(三)ArrayList常见方法的使用
@[toc]## 一.什么是ArrarListArrayList是Java中的一个动态数组类,可以根据实际需要自动调整数组的大小.ArrayList是基于数组实现的,它内部维护的是一个Object数组 ...
- 【生活技巧记录】歌词Lyric生成及音乐标签嵌入
前置工具准备: BesLyric:一款专门制作 网易云音乐 LRC 滚动歌词的软件! 搜索.下载.制作 歌词更方便! Foobar 2000:一款适用于 Windows 平台的高级免费软件音频播放器 ...
- JavaWeb开发-HTML基础学习
1.HTML的基本语法 HTML是什么?:HTML是一种超文本标记语言,负责网页的结构,设计页面的元素内容等 超文本:超越文本限制,除了文本信息,还可以定义图片,音频,视频等 标记语言:由标签构成的语 ...
- 【GKCTF 2020】ez三剑客
[GKCTF 2020]ez三剑客 收获 gopher协议SSRF 多利用github搜索已存在的函数漏洞 CMS审计的一些方法 1. ezweb 打开题目给了一个输入框,能够向输入的url发送htt ...
- Mybatis|MybatisPlus批量插入
创建一个SpringBoot工程 <?xml version="1.0" encoding="UTF-8"?> <project xmlns= ...
- Codeforces-470 div2 C题
C. Producing Snow time limit per test 1 second memory limit per test 256 megabytes input standard in ...
- 初次认识 Git (v2.x)
什么是版本控制? 版本控制,也称为源代码控制,是一种跟踪和管理软件代码变更的实践.版本控制系统是软件工具,可帮助软件团队管理源代码随时间推移而发生的变更.随着开发环境的加速,版本控制系统可以帮助软件团 ...
- 中企网安信息科技:协同办公OA信息化管理系统概述
由华企网安总公司北京中企网安信息科技有限责任公司开发的<协同办公OA信息化管理系统>,获得国家版权局颁发的计算机软件著作权登记证书. 协同办公OA信息化管理系统是一种综合性的软件系统,用于 ...
- TypeScript Vs JavaScript 区别
一.观察 1. JS 平常的复制类型 let val; val = 123; val = "123"; val = true; val = [1, 3, 5]; 注意点: 由于JS ...