B. Hossam and Friends
B. Hossam and Friends
题目大意:
有
思路:
遍历每个点作为区间的左端点,必须满足
证明:即前一项的右端点不可能比这一项的右端点大,如果大的话,说明
所以可以从后向前递推
code:
int n, m;
int a[N];
void solved()
{
cin >> n >> m;
for (int i = 1; i <= n + 1; ++i)
{
a[i] = n;
}
for (int i = 1; i <= m; ++i)
{
int x, y;
cin >> x >> y;
if (a[min(x, y)] > max(x - 1, y - 1))
a[min(x, y)] = max(x - 1, y - 1);
}
ll ans = 0;
for (int i = n; i > 0; --i)
{
if (a[i] > a[i + 1])
a[i] = a[i + 1];
ans += a[i] - i + 1;
}
cout << ans << endl;
}
如果您觉得阅读本文对您有帮助,请点一下“推荐”按钮,您的“推荐”将是我最大的写作动力!欢迎各位转载,但是未经作者本人同意,转载文章之后必须在文章页面明显位置给出作者和原文连接,否则保留追究法律责任的权利。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!