Codeforces Round 979 (Div. 2) (ABCD个人题解)

news/2024/10/20 2:27:01

刚打完ABC,本来以为10点半开打,结果10点就开始了,只是一个疲惫。
A:
只要将数组的最大值排第一,最小值排第二就ok了,所以答案就是(n-1)*(max-min);
AC代码:

#include<bits/stdc++.h>
#define int long long
#define endl '\n'
using namespace std;
const int N=2e5+10,mod=1e9+7;
void solve() {int n;cin>>n;vector<int> a(n+1);for(int i=1;i<=n;i++){cin>>a[i];}sort(a.begin()+1,a.begin()+n+1);cout<<(n-1)*(a[n]-a[1])<<endl;
}
signed main() {ios_base::sync_with_stdio(0), cin.tie(0), cout.tie(0);int t;cin >> t;while (t--)solve();return 0;
}

B:
赛时第一眼没看题,直接看样例,然后交了一发WA,其实只要s[0]='1',其余都为0就ok了,f(t)是 t的非空子序列 中只包含 0的个数, g(t)是 t的非空子序列中至少包含一个 1的个数。
只要s[0]='1',其余都为0,这样f(t)就始终会比g(t)小1。这样是最优的。
AC代码:

#include<bits/stdc++.h>
#define int long long
#define endl '\n'
using namespace std;
const int N=2e5+10,mod=1e9+7;
void solve() {int n;cin>>n;cout<<1;for(int i=1;i<n;i++){cout<<0;}cout<<endl;
}
signed main() {ios_base::sync_with_stdio(0), cin.tie(0), cout.tie(0);int t;cin >> t;while (t--)solve();return 0;
}

C:
首先,我想只要出现了11这样,无论如何,Alice都能胜利,其次如果两边只要有一个是1,Alice就能获胜。
AC代码:

#include<bits/stdc++.h>
#define int long long
#define endl '\n'
using namespace std;
const int N=2e5+10,mod=1e9+7;
void solve() {int n;cin>>n;string s;cin>>s;for(int i=0;i<s.size()-1;i++){if(s[i]=='1'&&s[i+1]=='1'){cout<<"Yes"<<endl;return;}}if(s[0]=='1'||s[s.size()-1]=='1'){cout<<"Yes"<<endl;}else cout<<"No"<<endl;
}
signed main() {ios_base::sync_with_stdio(0), cin.tie(0), cout.tie(0);int t;cin >> t;while (t--)solve();return 0;
}

D:
可以想一下,怎么才不能构成上升排列?
只要字符串出现LR,在L左边的数最多只能到达L的位置,不能再往右走了,所以只要左边存在a[i]>=L+1(该点必须到达L的右边),与此同时,R的右边也会存在相应的点需要到R左边来的,但我的AC代码中还傻傻的加了这个多余的判断,没什么必要。
明白上面之后,要怎么去实现呢,就维护一下从1~i的最大值,再去找符合条件的LR,然后统计一下符合条件的LR的个数num,只要num>0,就肯定不能构成上升排列,
然后,每次查询修改字符串的时候,看他会不会影响num数量的改变。这样就行了。
AC代码:

#include<bits/stdc++.h>
#define int long long
#define endl '\n'
using namespace std;
const int N=2e5+10,mod=1e9+7;
void solve() {int n, q;cin >> n >> q;vector<int> a(n + 1);vector<int> mx1(n + 1, 0);vector<int> mx2(n + 1, 1e18);//这个其实是没有什么必要的,mx2是多余的,后面也都可以删掉for (int i = 1; i <= n; i++) {cin >> a[i];}mx1[1]=a[1];mx2[n]=a[n];for (int i = 2; i <= n; i++) {mx1[i] = max(mx1[i-1], a[i]);}for (int i = n-1; i >= 1; i--) {mx2[i] = min(mx2[i+1], a[i]);}string s;cin >> s;s = " " + s;int num = 0;for (int i = 1; i <= n; i++) {if (s[i] == 'L' && s[i + 1] == 'R') {if (mx1[i] >= i + 1 && mx2[i + 1] <= i) {num++;}}}while (q--) {int x;cin >> x;if (s[x] == 'L') {if (s[x + 1] == 'R') {if (mx1[x] >= x + 1 && mx2[x + 1] <= x) {num--;}}if (s[x - 1] == 'L') {if (mx1[x - 1] >= x && mx2[x] <= x - 1) {num++;}}s[x] = 'R';} else {if (s[x - 1] == 'L') {if (mx1[x - 1] >= x && mx2[x] <= x - 1) {num--;}}if (s[x + 1] == 'R') {if (mx1[x] >= x + 1 && mx2[x + 1] <= x) {num++;}}s[x] = 'L';}
//        for(auto k:s) cout<<k;
//        cout<<endl;if (num) cout << "NO" << endl;else cout << "YES" << endl;}
}
signed main() {ios_base::sync_with_stdio(0), cin.tie(0), cout.tie(0);int t;cin >> t;while (t--)solve();return 0;
}

哎,今天ABC和CF的总结终于写完了,也是累了。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.ryyt.cn/news/73661.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈,一经查实,立即删除!

相关文章

Node.js安装及环境配置

1.下载nodejs https://nodejs.org/en/download直接下载安装包即可(什么fnm,nvm什么的fuck out,我就想装个nodeJs不想学什么包管理器的操作,需要多版本,我可以安装多个nodejs) 默认选项直接安装,不需要点任何配置 安装完毕后,建议在安装目录下,新建两个文件夹 node_cac…

我还没死

the Book of Genesis身边并没有朋友,以防那天死了所有人都不知道,所以弄一个这个,如果我活着,会以 \(\le 7d\) 的间隔重新发布,如果没有重新发布,可以尝试 qq 联系(2637322536),如果七天内没有回复,大概是死了,如果这篇博客被删除,说明我认为设立这篇博客的动机消失…

Codeforces Round 979 (Div. 2)题解记录

比赛链接:https://codeforces.com/contest/2030 A. A Gift From Orangutan 肯定最小值和最大值放前面最好,答案得解#include<iostream>#include<string.h>#include<map>#include<vector>#include<set>#include<unordered_set>#include&l…

AI工人操作行为流程规范识别系统

AI工人操作行为流程规范识别系统利用高清监控摄像头覆盖现场作业区域,AI工人操作行为流程规范识别系统通过图像识别和深度学习技术对作业人员的操作行为进行实时分析。AI工人操作行为流程规范识别系统能够准确识别工人的操作行为是否符合作业标准规定的流程和合规SOP,并根据设…

高级程序语言课第三次作业

2024高级语言程序设计:https://edu.cnblogs.com/campus/fzu/2024C 高级语言程序设计课程第三次个人作业:https://edu.cnblogs.com/campus/fzu/2024C/homework/13284 学号:102400115 姓名:洪育豪 作业内容:编写并运行书本第4章4.8编程练习题目中的第2题到第4题,第6题到第8题 编…

传送带下料口堵塞识别检测系统

传送带下料口堵塞识别检测系统利用AI视觉识别算法,传送带下料口堵塞识别检测系统通过现场监控摄像头对传送带的运输物料过程进行实时分析和识别。传送带下料口堵塞识别检测系统能够准确判断下料口是否出现堵塞现象,并及时抓拍有关图像进行记录。传送带下料口堵塞识别检测系统…

React/Vue 实现的前端应用, java/Go/Python 实现的后端应用,前后端分离的应用部署的最佳实践

前后端分离的应用(React 前端 + Java 后端)在部署过程中,需要考虑性能、扩展性、安全性、以及维护方便性等多个方面。下面我将详细介绍前后端分离应用的最佳实践,从架构设计、构建和打包、部署策略、CI/CD 集成、安全性措施等几个角度来描述。 微服务架构图示例壹.总体概述…

gradle配置代理

下载gradle项目 访问:https://start.spring.io/如上图所示,生成代码 配置代理服务器 买个国外的节点,使用 xshell 带代理方式连接,会暴露出 socks://localhost:1080建议开启 BBR 拥塞控制 # 要确保 linux 内核版本是4.9或更高,否则后面不用做了 uname -r # 加载 TCP BBR 模…