Codeforces Round 906 (Div. 2)(D推公式 E1分类讨论区间 E2 dp+线段树)

A - Doremy's Paint 3

推公式得

b1=b3=b5=b7....

b2=b4=b6=b8...

所以如果只有一个数或者两个数且数量差小于等于1即可

#include<bits/stdc++.h>
using namespace std;
const int N = 2e5+10,mod=1000003;
#define int long long
typedef long long LL;
typedef pair<int, int> PII;
const long long inf=1e17;
int n,m,k;
vector<int> g[N];
int a[N];
void solve()
{cin>>n;map<int,int> mp;for(int i=1;i<=n;i++) cin>>a[i],mp[a[i]]++;sort(a+1,a+1+n);if(mp.size()<=2){if(mp.size()==1){cout<<"Yes\n";return ;}else{auto x=mp[a[1]];auto y=mp[a[n]];if(abs(x-y)<=1){cout<<"Yes\n";}else cout<<"No\n";}}else cout<<"No\n";
}signed main()
{cin.tie(0);cout.tie(0);ios::sync_with_stdio(0);int t=1;cin>>t;while(t--) solve();
}

B - Qingshan Loves Strings

老规矩操作题先思考操作的性质

如果T串本身不合法那么就NO了,且我们插入肯定是在相同的时候插入

比如 相邻的0 或相邻的1,这时候要求T串首尾要不同且能接的上

#include<bits/stdc++.h>
using namespace std;
const int N = 2e5+10,mod=1000003;
#define int long long
typedef long long LL;
typedef pair<int, int> PII;
const long long inf=1e17;
int n,m,k;
vector<int> g[N];
int a[N];
bool check(string s){for(int i=1;i<s.size();i++){if(s[i]==s[i-1]) return false;}return true;
}
void solve()
{cin>>n>>m;string s,t;cin>>s>>t;if(check(s)){cout<<"YES\n";return ;    }else{if(!check(t)||t[0]!=t.back()){cout<<"NO\n";return ;}}for(int i=1;i<n;i++){if(s[i]==s[i-1]){if(s[i]==t[0]){cout<<"NO\n";return ;}}}cout<<"YES\n";
}signed main()
{cin.tie(0);cout.tie(0);ios::sync_with_stdio(0);int t=1;cin>>t;while(t--) solve();
}

C:C - Qingshan Loves Strings 2

看范围100 所以可以n^2去暴力

考虑插入哪个位置

如果 0XXXX0,因为只能插入 01 那么这个只能插入到翻转位置后的那个位置,否则就是无效插入

如果是1XXXX1,因为只能插入01 只能插入到第一个字母的前面

所以可得 如果当前是0 那么插入当前位置的翻转后的位置,如果当前是1,那么插入到当前位置的前面的位置

#include<bits/stdc++.h>
using namespace std;
const int N = 2e5+10,mod=1000003;
#define int long long
typedef long long LL;
typedef pair<int, int> PII;
const long long inf=1e17;
int n,m,k;
vector<int> g[N];
int a[N];
int check(string s){int n=s.size()-1;for(int i=1;i<=(n+1)/2;i++){if(s[i]==s[n-i+1]){return i;}}return 0;
}
void solve()
{cin>>n;string s;cin>>s;vector<int> res;s="?"+s;for(int j=1;j<=300;j++){int x=check(s);if(!x){cout<<res.size()<<"\n";for(auto x:res) cout<<x<<" ";cout<<"\n";return ;}n=s.size()-1;//   cout<<s<<"\n";if(s[x]=='0'){res.push_back(n-x+1);string t;for(int i=0;i<=n-x+1;i++){t.push_back(s[i]);}t+="01";for(int i=n-x+1+1;i<=n;i++) t.push_back(s[i]);swap(s,t);}else{res.push_back(x-1);string t;for(int i=0;i<=x-1;i++){t.push_back(s[i]);}t+="01";for(int i=x;i<=n;i++) t.push_back(s[i]);swap(s,t);}}//  cout<<check(s)<<"\n";if(check(s)) cout<<-1<<"\n";else{cout<<res.size()<<"\n";for(auto x:res) cout<<x<<" ";cout<<"\n";return ;}
}signed main()
{cin.tie(0);cout.tie(0);ios::sync_with_stdio(0);int t=1;cin>>t;while(t--) solve();
}

D - Doremy's Connecting Plan

这是个推公式题,肯定是用已经联通的块连向其他点

设只有两个数

ai+ aj >=i*j*c

然后发现好像不太能合并,然后可以想到1如果i=1,那么就单纯的变成

0>=j*c-aj,然后后面一直用1点去联通即可

证明

ai + aj>=i*j*c

a1+ai<i*c

a1+aj<j*c

假设只能连 i j的点,不能先连 1点,

用反证法得

a1+a1<(i+j-i*j)*c

因为i和j不能为1

所以这个(i+j-i*j)肯定是负数,不满足等式,所以证明如果能连i和j点,必然可以先连1点

#include<bits/stdc++.h>
using namespace std;
const int N = 2e5+10,mod=1000003;
#define int long long
typedef long long LL;
typedef pair<int, int> PII;
const long long inf=1e17;
int n,m,k;
vector<int> g[N];
int a[N];
void solve()
{int c;cin>>n>>c;priority_queue<PII,vector<PII>,greater<PII>> q;for(int i=1;i<=n;i++){cin>>a[i];if(i!=1) q.emplace(i*c-a[i],i);}auto now=a[1];while(q.size()){auto t=q.top();if(now>=t.first){now+=a[t.second];q.pop();}else break;}if(q.size()) cout<<"No\n";else cout<<"Yes\n";
}signed main()
{cin.tie(0);cout.tie(0);ios::sync_with_stdio(0);int t=1;cin>>t;while(t--) solve();
}

E1 - Doremy's Drying Plan (Easy Version)

因为k=2,所以思考选哪两个区间

1.这两个区间相交

2.这两个区间不相交

因为只能去掉两个区间,所以如果有些点被大于两个区间得点覆盖直接去掉就行了,

对于第二个条件两个区间不相交,说明如果去掉某个区间,那么这个点只能被一个区间覆盖

所以我们预处理

s1:只被一个区间覆盖的点的前缀和

s2:只被两个区间覆盖的点的前缀和

然后第二个条件直接枚举每个区间的贡献的最大值和次大值相加即可

然后可能有人问万一最大值和次大值区间相交呢,这说明这个相交的点要被覆盖两次,

我们求这个用的是s1数组,所以不会重复计算贡献

即任意取两个区间

如果相交的部分至少被覆盖两次他们不会在s1的数组

不相交的部分相加即为第二个条件的答案

对于第一个条件

我们直接暴力枚举每个点,以当前端点为相交的部分即可

然后用个堆枚举即可

贡献就是 两个区间相交部分的s2区间和maxr到minl的s1部分

#include<bits/stdc++.h>
using namespace std;
const int N = 2e5+10,mod=1000003;
#define int long long
typedef long long LL;
typedef pair<int, int> PII;
const long long inf=1e17;
int n,m,k;
vector<int> g[N];
int a[N];
void solve()
{cin>>n>>m>>k;vector<int> s1(n+10),s2(n+10),d(n+10);vector<array<int,2>> a;for(int i=1;i<=m;i++){int x,y;cin>>x>>y;a.push_back({x,y});d[x]++,d[y+1]--;}int res=0;for(int i=1;i<=n;i++){d[i]+=d[i-1];if(d[i]==0) res++;if(d[i]==1) s1[i]++;if(d[i]==2) s2[i]++;s1[i]+=s1[i-1];s2[i]+=s2[i-1];}int cnt1=0,cnt2=0;for(int i=0;i<m;i++){int x=a[i][0],y=a[i][1];int cnt=s1[y]-s1[x-1];if(cnt>cnt1){cnt2=cnt1,cnt1=cnt;}else if(cnt>cnt2) cnt2=cnt;}int mx=cnt1+cnt2;priority_queue<PII> q;int idx=0;sort(a.begin(),a.end());for(int i=1;i<=n;i++){while(idx<m&&a[idx][0]<=i){q.emplace(a[idx][1],a[idx][0]);idx++;}while(q.size()&&q.top().first<i) q.pop();if(q.empty()) continue;auto t=q.top();q.pop();while(q.size()&&q.top().first<i) q.pop();q.push(t);if(q.size()>=2){auto t1=q.top();q.pop();auto t2=q.top();vector<int> c={t1.first,t1.second,t2.first,t2.second};sort(c.begin(),c.end());int cnt=s1[c[3]]-s1[c[0]-1]+(s2[c[2]]-s2[c[1]-1]);mx=max(mx,cnt);q.push(t1);}}cout<<res+mx<<"\n";
}signed main()
{cin.tie(0);cout.tie(0);ios::sync_with_stdio(0);int t=1;cin>>t;while(t--) solve();
}

E2 - Doremy's Drying Plan (Hard Version)

考虑dp

状态:第i个点没被区间覆盖,且已经使用了j次机会的最大值

!!!!重点使得当前i点没被区间覆盖

举例说明

当前点5,使用了5次机会可以由

第4个点使用了5次机会获得(为啥机会没-1呢

因为f[4]代表着没被区间覆盖,说明f[4]已经把前面能覆盖到4的点的区间已经删除了)

第3个点使用4次机会获得

这里要把4到5的区间删去

以此类推

所以我们要找这个区间的最大值了

因为可能我后面再加个6的点,但我不增加区间,他可以由f[4][5]和f[5][5]最大值获得

所以涉及区间查询最大值,但是k很小,直接暴力每个k开个线段树即可

#include<bits/stdc++.h>
using namespace std;
const int N = 2e5+10,mod=1000003;
#define int long long
typedef long long LL;
typedef pair<int, int> PII;
const long long inf=1e17;
int n,m,k;
vector<int> g[N];
int a[N];
struct node{int l,r,mx;
}tr[11][N*4];
void pushup(int p,int u){tr[p][u].mx=max(tr[p][u<<1].mx,tr[p][u<<1|1].mx);
}
void build(int p,int u,int l,int r)
{tr[p][u]={l,r,0};if(l==r) return ;int mid=l+r>>1;build(p,u<<1,l,mid);build(p,u<<1|1,mid+1,r);
}void modify(int p,int u,int x,int v){if(tr[p][u].l==tr[p][u].r&&tr[p][u].l==x){tr[p][u].mx=max(tr[p][u].mx,v);return ;}else{int mid = tr[p][u].l + tr[p][u].r >> 1;if(x <= mid) modify(p, u << 1, x,v);else modify(p, u << 1 | 1, x,v);pushup(p, u);}
}
int query(int p, int u, int l, int r) {if(!l && !r) return 0;if(l <= tr[p][u].l && r >= tr[p][u].r) return tr[p][u].mx;int mid = tr[p][u].l + tr[p][u].r >> 1;int res = 0;if(l <= mid) res = max(res, query(p, u << 1, l ,r));if(r > mid) res = max(res, query(p, u << 1 | 1, l, r));return res;
}void solve()
{cin>>n>>m>>k;vector<array<int,2>> seg;for(int i=0;i<=k;i++) build(i,1,1,n);vector<vector<int>> f(n+10,vector<int>(k+10));for(int i=0;i<m;i++){int x,y;cin>>x>>y;seg.push_back({x,y});}sort(seg.begin(),seg.end());multiset<PII> st;int res=0;for(int i=1,idx=0;i<=n;i++){while(idx<m&&seg[idx][0]<=i){st.insert({seg[idx][1],seg[idx][0]});idx++;}if(st.size()<=k){vector<int> S{0};S.push_back(i);for(auto [r, l] : st) S.push_back(l);sort(S.begin(), S.end());for(int j = st.size(); j <= k; j ++ ) {for(int z = S.size() - 2, w = 0; w <= j && z >= 0; w ++, z -- ) {int l = S[z], r = S[z + 1] - 1;if(l > r) continue;f[i][j] = max(f[i][j], query(j - w, 1, l ,r) + 1);modify(j, 1, i, f[i][j]);}}res = max(res, f[i][k]);}PII tmp;while(st.size() && (tmp = *(st.begin())).first == i)st.extract(tmp);}cout<<res<<"\n";}signed main()
{cin.tie(0);cout.tie(0);ios::sync_with_stdio(0);int t=1;cin>>t;while(t--) solve();
}

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

第三方实验室LIMS管理系统源码,asp.net LIMS源码

LIMS实验室信息管理系统源码 LIMS系统的功能根据实验室的规模和任务而有所不同&#xff0c;其系统主要功能包括:系统维护、基础数据编码管理&#xff0c;样品管理、数据管理、报告管理、报表打印、实验材料管理、设备管理等。它可以取代传统的手工管理模式而给检测实验室带来巨…

java获取第n次出现字符串前后面字符串,如:截取第二个逗号后面的数据

java获取第n次出现字符串前后面字符串&#xff0c;如&#xff1a;截取第二个逗号后面的数据 方法&#xff1a; /*** 获取指定第几位字符串后面字符串&#xff0c;如&#xff1a;截取第二个逗号后面的数据** param str:要处理的字符串* param mediumStr&#xff1a;根据截取的媒…

时间序列异常检测14篇顶会论文合集,附必备工具和数据集

今天来聊聊一个在量化交易、网络安全检测、自动驾驶汽车和大型工业设备的日常维护等领域都有重要作用的研究主题&#xff1a;时间序列异常检测。 时间序列异常检测是一种在时间序列数据中识别和标识与预期模式、趋势或行为不符的异常点或事件的技术。鉴于它如此广泛的应用范围…

18、串口通信

串口介绍 串口是一种应用十分广泛的通讯接口&#xff0c;串口成本低、容易使用、通信线路简单&#xff0c;可实现两个设备的互相通信。 单片机的串口可以使单片机与单片机&#xff0c;单片机与电脑、单片机与各式各样的模块互相通信&#xff0c;极大的扩展了单片机的应用范围&…

MySQL InnoDB Cluster

MySQL InnoDB Cluster 一、InnoDB Cluster 基本概述 MySQL InnoDB Cluster 为 MySQL 提供了一个完整的高可用解决方案。通过使用 MySQL Shell 提供的 AdminAPI,你可以轻松地配置和管理一组至少由3个MySQL服务器实例组成的 InnoDB 集群。 InnoDB 集群中的每个 MySQL 服务器实例…

JRT和检验共用的打印层实现

之前对接的打印和导出是C#实现的&#xff0c;如果要完全Java化就需要用Java把打印元素绘制协议用Java实现&#xff0c;这次介绍实现主体搭建&#xff0c;最终使JRT达到完全信创和跨平台目标。到这篇后&#xff0c;所有的Java难题都解决完毕&#xff0c;几天到几周之内就可以把打…

(二进制、八进制、十进制、十六进制)的进制转换

整型有4种进制形式&#xff1a; 1.十进制&#xff1a; 都是以0-9这九个数字组成&#xff0c;不能以0开头。 2.二进制&#xff1a; 由0和1两个数字组成。 3.八进制&#xff1a; 由0-7数字组成&#xff0c;为了区分与其他进制的数字区别&#xff0c;开头都是以0开始。 4.十六进制…

聚类算法的算法原理

聚类算法是机器学习中常用的一种无监督学习方法&#xff0c;其主要目标是将数据集划分为具有相似特征的组或簇。这种算法在数据挖掘、模式识别、社交网络分析等领域有着广泛的应用。聚类算法的核心思想是通过计算数据点之间的相似度或距离&#xff0c;将相似的数据点聚集在一起…

WordPress 粘贴图片上传插件

找了很久&#xff0c;发现一款不错的插件&#xff0c;允许我们直接粘贴图片文件并且上传到媒体库。以前的插件上传后媒体库不会显示&#xff0c;这个要显示。 启用后编辑器会有一个图标&#xff0c;如果开启&#xff0c;那么久可以截图后直接粘贴了。 学习资料源代码&#xf…

TR转发路由器测评—云企业网实现跨地域跨VPC的网络互通测评实战【阿里云产品测评】

文章目录 一.转发路由器 Transit Router 测评1.1 准备阶段1.2 本文测评收获1.3 什么是云企业网实例、转发路由器实例和云数据传输服务 二.使用云企业网实现跨地域跨VPC的网络互通2.2 **测试连通性**2.3 网络拓扑如下&#xff1a; 心得&#xff1a;总结&#xff1a; 声明&#x…

基于SpringBoot房屋租赁系统

摘 要 社会的发展和科学技术的进步&#xff0c;互联网技术越来越受欢迎。网络计算机的生活方式逐渐受到广大人民群众的喜爱&#xff0c;也逐渐进入了每个用户的使用。互联网具有便利性&#xff0c;速度快&#xff0c;效率高&#xff0c;成本低等优点。 因此&#xff0c;构建符…

JSON.stringify方法详解 后端接受JSON数据格式

1、方法定义&#xff1a;JSON.stringify(value, replacer, space) 参数说明&#xff1a; value&#xff1a;js对象 replacer&#xff1a;替换对象&#xff0c;可以是一个方法、对象或数组&#xff0c;将value按照替换规则展示。 space&#xff1a;填充参数&#xff0c;可以是数…

Python排序算法大比拼:快速排序 VS 归并排序

更多资料获取 &#x1f4da; 个人网站&#xff1a;ipengtao.com 快速排序和归并排序是两种常见的排序算法&#xff0c;在Python中有着重要的应用。本文将深入探讨这两种算法的原理和实现&#xff0c;并提供丰富的示例代码来说明它们的工作方式。 快速排序算法 def quicksort…

NSSCTF第13页(3)

[FSCTF 2023]巴巴托斯&#xff01; 看见个输入路径&#xff0c;打了半天没进去&#xff0c;php伪协议也打不进去&#xff0c; 用dirsearch扫一下 看了半天才看出来&#xff0c;那串英文 Access Denied! I love FSCTF Browser 是要用FSCTF浏览器&#xff0c;改一下ua头就行了…

数字图像处理(实践篇)十二 基于小波变换的图像降噪

目录 一 基于小波变换的图像降噪 &#xff08;1&#xff09;小波变换基本理论 &#xff08;2&#xff09;小波分析在图像处理中的应用 &#xff08;3&#xff09;小波变换原理 &#xff08;4&#xff09;小波降噪原理 &#xff08;5&#xff09;小波降噪算法的实现 &…

vsVode C++开发远程虚拟机工程配置

在使用VS Code进行C/C的开发过程中&#xff0c;有三个至关重要的配置文件&#xff0c;分别是 tasks.json, launch.json 和 c_cpp_properties.json 1. tasks.json tasks.json 是在 vscode 中辅助程序编译的模块&#xff0c;可以代你执行类似于在命令行输入 “gcc hello.c -o h…

解决webpack打包生成gz格式css/js文件没法在nginx使用的问题--全网唯一正确

本文绝对是全网解决这个问题唯一正确的文章&#xff0c;没有之一&#xff01; 很多人都说开启nginx gzip压缩&#xff0c;这些人完全是胡说八道&#xff01;你们到底懂不懂叫gzip压缩啊&#xff1f;&#xff01; 不信你就试试&#xff0c;如果css/js只有gz文件&#xff0c;ng…

排序分析(Ordination analysis)及R实现

在生态学、统计学和生物学等领域&#xff0c;排序分析是一种用于探索和展示数据结构的多元统计技术。这种分析方法通过将多维数据集中的样本或变量映射到低维空间&#xff0c;以便更容易理解和可视化数据之间的关系。排序分析常用于研究物种组成、生态系统结构等生态学和生物学…

中伟视界:AI盒子中的报警预录像功能能解决什么问题?实现原理是怎样的?

现代社会智能安防已成为各行各业的重要一环&#xff0c;而AI盒子中的报警预录像功能更是智能安防的一大利器。这一功能能够解决很多安防方面的难题&#xff0c;其实现原理更是技术创新的体现。 首先&#xff0c;让我们来看看AI盒子中的报警预录像功能能解决哪些问题。在传统的安…

Prosys OPC Client连接OPC DA

Prosys OPC Client连接OPC DA Prosys OPC 客户端将帮助排除 OPC 连接故障并测试 OPC 服务器。 您可以读写数据、浏览服务器以及导出和导入地址空间。 OPC 客户端轻巧、快速且易于使用。 支持 OPC DA 1.0a 和 OPC DA 2.05a 官方地址: https://www.prosysopc.com/products/opc-…