这道题数据太小啦!先枚举i,j表示从第i天到第j天不更改航线的费用。

然后直接跑最短路算法(我用的是Q版男朋友算法)

动归方程显然是f[i] = min(f[i], f[j] + cost[j+1][i] + k)

(PS:这道题一开始看成了某航线是否被ban...大家要注意啊!还有n和m的问题,各种别扭...)

代码(Submit Time
2016-01-10 15:48:24):

#include <cstdio>
#include <deque>
using namespace std;
const int maxd = 105;
const int maxn = 25;
const int INF = 1000000007;
int d, n, k, m, q;
int cost[maxd][maxd];
int f[maxd];
bool ban[maxn * maxn][maxd];
bool ava[maxd];
int min(int a, int b) {
return a < b ? a : b;
}
int getint() {
int r = 0, k = 1;
char c;
for (c = getchar(); c < '0' || c > '9'; c = getchar() ) if (c == '-') k = -1;
for (; '0' <= c && c <= '9'; c = getchar() ) r = r * 10 - '0' + c;
return r * k;
}
struct edge_type {
int v, next, w;
} edge[maxn * maxn]; int cnte = 0, h[maxn];
void ins(int u, int v, int w) {
edge[++cnte].v = v;
edge[cnte].w = w;
edge[cnte].next = h[u];
h[u] = cnte;
}
deque<int> Q;
int dis[maxn];
bool inque[maxn];
void SPFA() {
Q.push_back(1);
dis[1] = 0;
inque[1] = true;
for (int i = 2; i <= n; ++i) dis[i] = INF;
int now;
while (!Q.empty()) {
now = Q.front(); Q.pop_front(); inque[now] = false;
for (int i = h[now]; i; i = edge[i].next) {
int v = edge[i].v;
if (!ava[v]) continue;
if (dis[v] > dis[now] + edge[i].w) {
dis[v] = dis[now] + edge[i].w;
if (!inque[v]) {
Q.push_back(v);
inque[v] = true;
}
}
}
}
}
int main() {
d = getint(); n = getint(); k = getint(); m = getint();
int u, v, w;
for (int i = 0; i < m; ++i) {
u = getint(); v = getint(); w = getint();
ins(u, v, w); ins(v, u, w);
}
q = getint();
for (int i = 0; i < q; ++i) {
u = getint(); v = getint(); w = getint();
for (int j = v; j <= w; ++j) ban[u][j] = true;
}
for (int i = 1; i <= d; ++i)
for (int j = i; j <= d; ++j)
{
for (int mt = 1; mt <= n; ++mt) {
ava[mt] = true;
for (int t = i; t <= j; ++t)
if (ban[mt][t]) {
ava[mt] = false;
break;
}
}
SPFA();
if (dis[n] == INF) cost[i][j] = INF;
else cost[i][j] = dis[n] * (j-i+1);
}
for (int i = 1; i <= d; ++i) {
f[i] = cost[1][i];
for (int j = 1; j <= i; ++j) f[i] = min(f[i], f[j] + cost[j+1][i] + k);
}
printf("%d\n", f[d]);
return 0;
}

BZOJ 1003 物流运输【最短路】【动态规划】的更多相关文章

  1. BZOJ 1003 - 物流运输 - [最短路+dp]

    题目链接:https://www.lydsy.com/JudgeOnline/problem.php?id=1003 Time Limit: 10 Sec Memory Limit: 162 MB D ...

  2. BZOJ 1003 物流运输 题解 【SPFA+DP】

    BZOJ 1003 物流运输 题解 Description 物流公司要把一批货物从码头A运到码头B.由于货物量比较大,需要n天才能运完.货物运输过程中一般要转停好几个码头.物流公司通常会设计一条固定的 ...

  3. BZOJ 1003 物流运输 (动态规划 SPFA 最短路)

    1003: [ZJOI2006]物流运输 Time Limit: 10 Sec Memory Limit: 162 MB Submit: 5590 Solved: 2293 [Submit][Stat ...

  4. BZOJ 1003 物流运输 (dp + dijkstra)

    1003: [ZJOI2006]物流运输 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 8672  Solved: 3678[Submit][Stat ...

  5. BZOJ 1003 物流运输trans dijstra+dp

    1003: [ZJOI2006]物流运输trans Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 3896  Solved: 1608[Submit] ...

  6. BZoj 1003 物流运输 DP+最短路

    2013-09-11 09:56 W[I]代表前I天能取得的最小花费,假设在第J天更改一次路线,那么如果有 W[I]>W[J]+第j+1到第I天的最小花费+更改路线的花费(K) 那么更新W[I] ...

  7. BZOJ 1003 物流运输trans

    Description 物流公司要把一批货物从码头A运到码头B.由于货物量比较大,需要n天才能运完.货物运输过程中一般要转停好几个码头.物流公司通常会设计一条固定的运输路线,以便对整个运输过程实施严格 ...

  8. [BZOJ]1003 物流运输(ZJOI2006)

    挖坑,日常划水. 从BZOJ上的AC人数来看这题确实不难,但做这种题的常见思路让小C决定还是mark一下. Description 物流公司要把一批货物从码头A运到码头B.由于货物量比较大,需要n天才 ...

  9. BZOJ 1003 物流运输

    最短路+dp. #include<iostream> #include<cstdio> #include<cstring> #include<algorith ...

随机推荐

  1. java5

    1:final关键字(掌握) (1)是最终的意思,可以修饰类,方法,变量. (2)特点: A:它修饰的类,不能被继承. B:它修饰的方法,不能被重写. C:它修饰的变量,是一个常量. (3)面试相关: ...

  2. .NET 获取客户端的操作系统版本、浏览器版本和IP地址

    我们在使用.NET做网站的时候,很多情况下需要需要知道客户端的操作系统版本和浏览器版本,怎样获取客户端的操作系统和浏览器版本呢?我们可以通过分析UserAgent来获取. .NET 获取客户端的操作系 ...

  3. ubuntu14.0.4.3 devstack 安装openstack

    参考网址: http://www.chenshake.com/install-ubuntu-14-04-devstack/ 现在装完一切正常,就是不能重启,一旦重启VM,会导致给br-ex设置的IP地 ...

  4. 关于DOM的一些操作 整理 积累

    var chils= s.childNodes;  //得到s的全部子节点 var par=s.parentNode;   //得到s的父节点 var ns=s.nextSbiling;   //获得 ...

  5. asp.net 数据库面试题(基础)

    今天到某公司笔试,数据库考的比较多,但是说老实话,考的也比较基础.现在趁回忆得起来,将数据库知识简单整理如下: 一.建表指令 比如创建一个学生表student,它由学号Sno,姓名Sname,性别Ss ...

  6. Codeforces Round #353 (Div. 2)

    数学 A - Infinite Sequence 等差数列,公差是0的时候特判 #include <bits/stdc++.h> typedef long long ll; const i ...

  7. 怎样上传网页到ftp中

    1.下载filezilla软件软件并安装 打开刚刚装好的FileZilla,点击菜单中的"文件"             2.点击站点管理器 3.点击新站点

  8. 【Cocos2d-x游戏开发】细数Cocos2d-x开发中那些常用的C++11知识

    自从Cocos2d-x3.0开始,Cocos2dx就正式的使用了C++11标准.C++11简洁方便的特性使程序的可拓展性和可维护性大大提高,也提高了代码的书写速度. 下面我们就来一起学习一下Cocos ...

  9. std::string的split函数

    刚刚要找个按空格分离std::string的函数, 结果发现了stackoverflow上的这个问题. 也没仔细看, 直接拿来一试, 靠, 不对啊, 怎么分离后多出个空字符串, 也就是 "a ...

  10. oracle 数据库 时间差 年数、月数、天数、小时数、分钟数、秒数

    declare l_start date := to_date('2015-04-29 01:02:03', 'yyyy-mm-dd hh24:mi:ss'); l_end date := to_da ...