当对问题建立数学模型后,发现其是一个差分方程组,那么问题可以转换为最短路问题,一下分别选用Bellmanford-SPFA解题


ZOJ2770-Burn the Linked Camp

//差分约束方程组-转换为最短路问题
//d[v] <= d[u] + dis[u][v] -> d[v] - d[u] <= dis[u][v]
//Time:110Ms Memory:12116
#include<iostream>
#include<cstring>
#include<cstdio>
using namespace std; #define MAXN 1005
#define INF 0x3f3f3f3f struct Edge {
int u, v, w;
Edge(){}
Edge(int uu,int vv,int ww):u(uu),v(vv),w(ww){}
}e[MAXN*MAXN]; int n, m, le;
int sd[MAXN]; //从1-i兵营总共最多多少人
int d[MAXN]; bool bellmanford(int x)
{
memset(d, INF, sizeof(d));
d[x] = 0;
for (int i = 0; i < n; i++)
{
for (int j = 0; j < le; j++)
{
int u = e[j].u, v = e[j].v;
int w = e[j].w;
if (d[v] > d[u] + w)
d[v] = d[u] + w;
}
}
for (int i = 0; i < le; i++)
if (d[e[i].v] > d[e[i].u] + e[i].w)
return false;
return true;
} int main()
{
//freopen("in.txt", "r", stdin);
while (scanf("%d%d", &n, &m) != EOF)
{
int a, b, w;
le = 0;
for (int i = 1; i <= n; i++)
{
scanf("%d", &sd[i]);
sd[i] += sd[i - 1];
e[le++] = Edge(i, i - 1, 0);
e[le++] = Edge(i - 1, i, sd[i] - sd[i-1]);
}
for (int i = 1; i <= m; i++)
{
scanf("%d%d%d", &a, &b, &w);
e[le++] = Edge(b, a - 1, -w);
//e[le++] = Edge(a - 1, b, sd[b] - sd[a - 1]);
}
if (!bellmanford(n)) printf("Bad Estimations\n");
else printf("%d\n", -d[0]);
}
return 0;
}

POJ1201_Intervals

//差分约束系统-SPFA
//求一个集合Z中最少有多少个数
//给定Z与n个区间的最小交集个数
//Time:407Ms Memory:2624K
#include<iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>
#include<queue>
using namespace std; #define MAX 50005
#define INF 0x3f3f3f3f struct Edge {
int u, w, next;
Edge(){}
Edge(int uu,int ww,int nn):u(uu),w(ww),next(nn){}
}e[3*MAX]; int l, r, m, le;
int h[MAX];
int d[MAX];
bool v[MAX]; void spfa(int x)
{
memset(d, INF, sizeof(d));
memset(v, false, sizeof(v));
d[x] = 0;
queue<int> q;
q.push(x); v[x] = true;
while (!q.empty()) {
int cur = q.front();
q.pop(); v[cur] = false;
for (int i = h[cur]; i != -1; i = e[i].next)
{
int u = e[i].u, w = e[i].w;
if (d[u] > d[cur] + w) {
d[u] = d[cur] + w;
if (!v[u]) {
v[u] = true; q.push(u);
}
}
}
}
} int main()
{
memset(h, -1, sizeof(h));
scanf("%d", &m);
l = INF; r = 0;
for (int i = 1; i <= m; i++)
{
int a, b, w;
scanf("%d%d%d", &a, &b, &w);
r = max(b, r);
l = min(a, l);
e[le] = Edge(a - 1, -w, h[b]);
h[b] = le++;
}
for (int i = l; i <= r; i++)
{
e[le] = Edge(i - 1, 0, h[i]);
h[i] = le++;
e[le] = Edge(i, 1, h[i - 1]);
h[i - 1] = le++;
} spfa(r); printf("%d\n", d[r] - d[l-1]); return 0;
}

ACM/ICPC 之 差分约束系统两道(ZOJ2770-POJ1201)的更多相关文章

  1. ACM/ICPC 之 Floyd范例两道(POJ2570-POJ2263)

    两道以Floyd算法为解法的范例,第二题如果数据量较大,须采用其他解法 POJ2570-Fiber Network //经典的传递闭包问题,由于只有26个公司可以采用二进制存储 //Time:141M ...

  2. ACM/ICPC 之 SPFA范例两道(POJ3268-POJ3259)

    两道以SPFA算法求解的最短路问题,比较水,第二题需要掌握如何判断负权值回路. POJ3268-Silver Cow Party //计算正逆最短路径之和的最大值 //Time:32Ms Memory ...

  3. ACM/ICPC 之 SPFA练习两道(ZOJ3088-ZOJ3103)

    两道题都需要进行双向SPFA,比范例复杂,代码也较长,其中第二题应该可以用DFS或者BFS做,如果用DFS可能需要的剪枝较多. ZOJ3088-Easter Holydays //利用SPFA找出下降 ...

  4. 『ACM C++』Virtual Judge | 两道基础题 - The Architect Omar && Malek and Summer Semester

    这几天一直在宿舍跑PY模型,学校的ACM寒假集训我也没去成,来学校的时候已经18号了,突然加进去也就上一天然后排位赛了,没学什么就去打怕是要被虐成渣,今天开学前一天,看到最后有一场大的排位赛,就上去试 ...

  5. ACM/ICPC 之 欧拉回路两道(POJ1300-POJ1386)

    两道有关欧拉回路的例题 POJ1300-Door Man //判定是否存在从某点到0点的欧拉回路 //Time:0Ms Memory:116K #include<iostream> #in ...

  6. ACM/ICPC 之 两道dijkstra练习题(ZOJ1053(POJ1122)-ZOJ1053)

    两道较为典型的单源最短路径问题,采用dijkstra解法 本来是四道练习题,后来发现后面两道用dijkstra来解的话总觉得有点冗余了,因此暂且分成三篇博客(本篇以及后两篇). ZOJ1053(POJ ...

  7. 【转】lonekight@xmu·ACM/ICPC 回忆录

    转自:http://hi.baidu.com/ordeder/item/2a342a7fe7cb9e336dc37c89 2009年09月06日 星期日 21:55 初识ACM最早听说ACM/ICPC ...

  8. POJ1201 Intervals(差分约束系统)

    与ZOJ2770一个建模方式,前缀和当作点. 对于每个区间[a,b]有这么个条件,Sa-Sb-1>=c,然后我就那样连边WA了好几次. 后来偷看数据才想到这题还有两个隐藏的约束条件. 这题前缀和 ...

  9. ACM - ICPC World Finals 2013 C Surely You Congest

    原题下载:http://icpc.baylor.edu/download/worldfinals/problems/icpc2013.pdf 题目翻译: 试题来源 ACM/ICPC World Fin ...

随机推荐

  1. [Angularjs]asp.net mvc+angularjs+web api单页应用之CRUD操作

    写在前面 前篇文章整理了angularjs学习目录,有园子里的朋友问我要这方面的demo,周末也没什么事,就在之前的单页应用的demo上面添加了增删改查的操作.代码比较简单,这里只列举比较重要的代码片 ...

  2. centos yum 安装

    LINUX下YUM源配置 1.确保RHEL5中已经安装了yum [root@lvs-master ~]# rpm -qa |grep yumyum-metadata-parser-1.1.2-3.el ...

  3. vim基础命令

    2015-06-04 by komilevim基础命令 打开一个文件 vim index.php 几种模式说明Normal Mode也就是最一般的普通模式,默认进入vim之后,处于这种模式.Inser ...

  4. Ruby类的创建与使用

    Ruby是一种面向对象编程语言,这意味着它操纵的编程结构称为"对象" 先上代码, 了解类的定义与使用方式 class Computer $manufacturer = " ...

  5. post提交表单

    <script type="text/javascript"> $(function () { $("#btnRefresh1").click(fu ...

  6. 解决Button设置disabled后无法执行后台代码问题

    一.开始调式下面的程序,发现Button在js中设置disabled后无法执行后台代码(btnsave_Click)问题 <asp:Button ID="btnsave" r ...

  7. FineUI第十六天---表格的排序和分页

    表格的排序和分页 1.表格的排序需要: AllowSorting:是否允许排序. SortColumn:当前排序的列ID,当然也可以不设置此属性,而是在后台初始化代码中直接指定默认排序字段. Sort ...

  8. 关于cin,getchar(),scanf()的注意事项(转)

      问题描述一:(分析scanf()和getchar()读取字符) scanf(), getchar()等都是标准输入函数,一般人都会觉得这几个函数非常简单,没什么特殊的.但是有时候却就是因为使用这些 ...

  9. iOS开发——高级篇——UIDynamic 物理引擎

    一.UIDynamic 1.简介什么是UIDynamicUIDynamic是从iOS 7开始引入的一种新技术,隶属于UIKit框架可以认为是一种物理引擎,能模拟和仿真现实生活中的物理现象重力.弹性碰撞 ...

  10. iOS开发——UI基础-UIImage,UIImageView的使用

    1.UIImage 创建UIImage的两种方法 UIImage *image = [UIImage imageNamed:imageNmae]; UIImage *image = [UIImage ...