Codeforces 1626 C
1626 C
题意
抽象出题意:给出n个区间的结尾以及它的区间长度,然后每一段连续区间的贡献为 ,求总贡献。
思路
处理出每个区间的开头结尾,排序后处理每个连续区间就行了。
代码
void solve()
{
cin>>n;
for(int i=1;i<=n;i++) cin>>p[i].second;
for(int i=1,x;i<=n;i++) cin>>x,p[i].first=p[i].second-x+1;
sort(p+1,p+1+n);
int ans=0,l=p[1].first,r=p[1].second;
for(int i=2;i<=n;i++)
{
if(p[i].first>r) ans+=(2+r-l)*(r-l+1)/2,l=p[i].first,r=p[i].second;
else r=max(r,p[i].second);
}
ans+=(2+r-l)*(1+r-l)/2;
cout<<ans<<endl;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 【杭电多校比赛记录】2025“钉耙编程”中国大学生算法设计春季联赛(1)