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

【交互 / 差分约束】

题目

代码

#include <bits/stdc++.h>
using namespace std;
using ll = long long;const int N = 10510;
const int M = 200 * 500 + 10;
int h[N], ne[M], e[M], w[M], idx;
ll d[N];
int n, m;
bool st[N];
int cnt[N];void add(int a, int b, int c)
{w[idx] = c, e[idx] = b, ne[idx] = h[a], h[a] = idx++;
}
ll spfa()
{memset(d, 0x3f, sizeof d);queue<int> q;for(int i = 1; i <= n+m; i++)q.push(i);while(q.size()){int u = q.front(); q.pop();st[u] = 0;for(int i = h[u]; ~i; i = ne[i]){int j = e[i];if(d[j] > d[u] + w[i]){d[j] = d[u] + w[i];cnt[j] += 1;if(cnt[j] >= m) return -1;if(!st[j]){q.push(j);st[j] = 1;}}}}ll maxx = d[1], minn = d[1];for(int i = 2; i <= m; i++)maxx = max(maxx, d[i]), minn = min(minn, d[i]);return maxx - minn;
}	
int main()
{	cin >> n >> m;memset(h, -1, sizeof h);for(int t = 1; t <= n; t++){int l, r, p, q, ans;cin >> l >> r >> p >> q >> ans;for(int i = l; i <= r; i++)add(i, m+t, 0);for(int j = p; j <= q; j++)add(m+t, j, -ans);}ll ans = spfa();if(ans == -1) puts("No Solution");else cout << ans;
}

http://www.lryc.cn/news/2379203.html

相关文章:

  • 宝塔面板部署前后端项目SpringBoot+Vue2
  • 现代生活健康养生新视角
  • 鸿蒙Next API17新特性学习之如何使用新增鼠标轴事件
  • 多模态大语言模型arxiv论文略读(八十一)
  • 3.4/Q2,Charls最新文章解读
  • 通过觅思文档项目实现Obsidian文章浏览器在线访问
  • Python列表全面解析:从入门到精通
  • 5月18总结
  • 赋予AI更强的“思考”能力
  • Linux Bash | Capture Output / Recall
  • 2025/5/18
  • 基于Quicker构建从截图到公网图像链接获取的自动化流程
  • LeetCode算 法 实 战 - - - 双 指 针 与 移 除 元 素、快 慢 指 针 与 删 除 有 序 数 组 中 的 重 复 项
  • uniapp自定义日历计划写法(vue2)
  • Java IO框架
  • 数据库2——查询
  • Mamba LLM 架构简介:机器学习的新范式
  • Android 性能优化入门(一)—— 数据结构优化
  • 数据库中的锁机制
  • 【网络入侵检测】基于Suricata源码分析运行模式(Runmode)
  • AI日报 - 2025年05月19日
  • Spring源码主线全链路拆解:从启动到关闭的完整生命周期
  • Linux常用命令(十四)
  • 规则联动引擎GoRules初探
  • 基于OpenCV中的图像拼接方法详解
  • AI大模型学习二十六、使用 Dify + awesome-digital-human-live2d + ollama + ChatTTS打造数字人
  • HTML-3.2 表格的跨行跨列(课表制作实例)
  • Spring Cloud Sentinel 快速入门与生产实践指南
  • 系统架构设计(十):结构化编程
  • 标准差和方差是什么