当前位置: 首页 > news >正文

Codeforces Round 1046 (Div. 2) vp补题

只是签了三道题就燃尽了…
原题连接
在这里插入图片描述

A

//不可能连续进三球 得分值差最多的只有00X00X00X00 
bool jud(int a,int b){if(a!=0&&b!=0&&max(a,b)-2*(min(a,b)+1)>=1)return 0;if(a==0||b==0){if(abs(a-b)>=3)return 0;}return 1;
}
void solve()
{int a,b,c,d;cin>>a>>b>>c>>d;if(jud(a,b)==0)return cout<<"no"<<endl,void();int d1=c-a,d2=d-b;	cout<<(jud(d1,d2)?"yes":"no")<<endl;
}

B 构造

void solve()
{int n,k;cin>>n>>k;string s;cin>>s;int cnt=0,id=0;while (id<n){if(s[id]!='1'){id++;continue;}int st=id;id++;while (id<n&&s[id]=='1'){id++;}cnt=max(cnt,id-st);}if(cnt>=k)cout<<"no"<<endl;//连续的1不能长于k 否则区间内不能满足没有最大值else{cout<<"yes"<<endl;int f=1,e=n;forr(i,0,n-1){if(s[i]=='0')cout<<e--<<' ';else cout<<f++<<' ';//不能是最大值的位置往小了填}cout<<endl;}
}

C dp 定长滑动窗口

一开始没理解好子序列的意思,以为是从头尾删去得到序列,导致第五个样例看不明白
看明白了转用dp,但是只记录了整洁数组的起始位置,没有注意到像333333这样的,可以取中间部分当作整洁数组,使用定长窗口处理

void solve()
{int n;cin>>n;forr(i,1,n)v[i].clear();vector<int>a(n+1),dp(n+1,0);// vector<int>cnt(n+1,0),st(n+1,-1);forr(i,1,n)cin>>a[i];forr(i,1,n){v[a[i]].push_back(i);//把位置放进去dp[i]=dp[i-1];if(v[a[i]].size()>=a[i]){//窗口dp[i]=max(a[i]+dp[v[a[i]][v[a[i]].size()-a[i]]-1],dp[i]);}// if(st[a[i]]==-1)st[a[i]]=i;//最优的可能不是开头 就好像滑动窗口// cnt[a[i]]++;// if(cnt[a[i]]==a[i]){// 	dp[i]=dp[st[a[i]]-1]+a[i];// 	st[a[i]]=-1;// 	cnt[a[i]]=0;// }else dp[i]=dp[i-1];}int ans=0;forr(i,1,n)ans=max(ans,dp[i]);// forr(i,1,n)cout<<dp[i]<<' ';cout<<endl;cout<<ans<<endl;
}

D 交互题 思维

首先要确定是离哪个点的曼哈顿距离
−1e9<xi,yi<1e9-1e9<x_i,y_i<1e91e9<xi,yi<1e9

  • 先移到右上角,X+2e9,Y+2e9X+2e9,Y+2e9X+2e9,Y+2e9,得到离m1=max(xi+yi)m1=max(x_i+y_i)m1=max(xi+yi)位置点的曼哈顿距离d1d1d1X+2e9−xi+Y+2e9−yi=X+Y+4e9−m1=d1X+2e9-x_i+Y+2e9-y_i=X+Y+4e9-m1=d1X+2e9xi+Y+2e9yi=X+Y+4e9m1=d1
  • 再移到右下角,X+2e9,Y−2e9X+2e9,Y-2e9X+2e9,Y2e9,得到离m2=max(xi−yi)m2=max(x_i-y_i)m2=max(xiyi)位置点的曼哈顿距离d2d2d2(X+2e9−xi)+(yi−(Y−2e9))=X−Y+4e9−m2=d2(X+2e9-x_i)+(y_i-(Y-2e9))=X-Y+4e9-m2=d2(X+2e9xi)+(yi(Y2e9))=XY+4e9m2=d2
  • 解方程X=d1+d2+m1+m2−8e92,Y=d1−d2+m1−m22X={{d1+d2+m1+m2-8e9}\over 2},Y={{d1-d2+m1-m2}\over 2}X=2d1+d2+m1+m28e9,Y=2d1d2+m1m2
const int N=1e6+10,M=6e3+10,mod=998244353,inf=1e9;
void solve(){int n;cin>>n;int m1,m2;m1=m2=-1e18;forr(i,1,n){int x,y;cin>>x>>y;m1=max(x+y,m1);m2=max(x-y,m2);}//右上int d1=0,d2=0;cout<<"? U "<<inf<<endl;fls;cin>>d1;cout<<"? U "<<inf<<endl;fls;cin>>d1;cout<<"? R "<<inf<<endl;fls;cin>>d1;cout<<"? R "<<inf<<endl;fls;cin>>d1;forr(i,1,4){cout<<"? D "<<inf<<endl;fls;cin>>d2;}int x=(d1+d2+m1+m2-8e9)/2,y=(d1-d2+m1-m2)/2;cout<<"! "<<x<<' '<<y<<endl;
}

X+Y=sm1,X−Y=sm2⇒X=sm1+sm22,Y=sm1−sm22X+Y=sm1,X-Y=sm2\Rightarrow X={{sm1+sm2}\over 2},Y={{sm1-sm2}\over 2}X+Y=sm1,XY=sm2X=2sm1+sm2,Y=2sm1sm2

E

需要tarjan 学习中…


文章转载自:

http://iiC7icze.qczyz.cn
http://EnE2u3Vv.qczyz.cn
http://YXXVb93a.qczyz.cn
http://5yRRfSjo.qczyz.cn
http://p7P4tQkF.qczyz.cn
http://L0H0y36F.qczyz.cn
http://0cMcfhNo.qczyz.cn
http://5atyo91v.qczyz.cn
http://2eOSR3Xn.qczyz.cn
http://0YPQP5o0.qczyz.cn
http://xx8AQjbC.qczyz.cn
http://ixLtKIe6.qczyz.cn
http://5wxhGkCQ.qczyz.cn
http://9exnBxoo.qczyz.cn
http://3uPmb3z8.qczyz.cn
http://5V26NiZI.qczyz.cn
http://mMQ8M03G.qczyz.cn
http://yv7grnxU.qczyz.cn
http://gYVtDOLE.qczyz.cn
http://aPQoL2p9.qczyz.cn
http://RQknV94k.qczyz.cn
http://BD2Ye3ao.qczyz.cn
http://TXHZtdEa.qczyz.cn
http://RmDSsCaY.qczyz.cn
http://KNm8ROSi.qczyz.cn
http://sVz7DaHQ.qczyz.cn
http://pkHkGprD.qczyz.cn
http://F4RU6CZt.qczyz.cn
http://rfINAQ3D.qczyz.cn
http://J2roxalm.qczyz.cn
http://www.dtcms.com/a/370195.html

相关文章:

  • 【LeetCode热题100道笔记】二叉树的右视图
  • Day22_【机器学习—集成学习(1)—基本思想、分类】
  • 自动化运维,ansible综合测试练习题
  • 【面试题】领域模型持续预训练数据选取方法
  • OpenHarmony之USB Manager 架构深度解析
  • 新服务器初始化:Git全局配置与SSH密钥生成
  • 主流分布式数据库集群选型指南
  • 【Proteus仿真】定时器控制系列仿真——秒表计数/数码管显示时间
  • python advance -----object-oriented
  • 开源与定制化对比:哪种在线教育系统源码更适合教育培训APP开发?
  • 【51单片机-B030】【protues仿真】基于51单片机万年历系统
  • mysql 是否“100%”地解决幻读?
  • 分布式系统的设计哲学:架构模式全面介绍与选型策略
  • windows11 安装charm成功
  • IPD流程落地:IPMT的开发评审逻辑
  • 数字化赋能全球扩张:名创优品携手巨益科技的信息化转型深度实践
  • OpenCV - 图像的IO操作
  • Windows 11 手动下载安装配置 uv、配置国内源
  • Wisdom SSH 是一款搭载强大 AI 助手的工具,能显著简化服务器配置管理流程。
  • Linux基础知识(二)
  • Redis 在互联网高并发场景下的应用--个人总结
  • 算法题-链表03
  • 版本发布流程手册:Release分支规范与Bug分级标准全解析
  • 目标检测中的池化层
  • react native 出现 FATAL EXCEPTION: OkHttp Dispatcher
  • HttpClient、OkHttp 和 WebClient
  • js逆向Webpack模块加载机制解析:从数组到JSONP
  • cuda-NCCL笔记(1)-- 初步了解使用NCCL
  • Lua 面向对象编程
  • 微信小程序(uniapp)实现连接蓝牙