BZOJ 1003 物流运输【最短路】【动态规划】

时间:2022-01-19 22:55:55

这道题数据太小啦!先枚举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 - 物流运输 - &lbrack;最短路&plus;dp&rsqb;

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

  2. BZOJ 1003 物流运输 题解 【SPFA&plus;DP】

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

  3. BZOJ 1003 物流运输 &lpar;动态规划 SPFA 最短路&rpar;

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

  4. BZOJ 1003 物流运输 &lpar;dp &plus; dijkstra&rpar;

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

  5. BZOJ 1003 物流运输trans dijstra&plus;dp

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

  6. BZoj 1003 物流运输 DP&plus;最短路

    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. &lbrack;BZOJ&rsqb;1003 物流运输&lpar;ZJOI2006&rpar;

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

  9. BZOJ 1003 物流运输

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

随机推荐

  1. 【转】PS学堂之一:展示一下自己做的圆形印章

    共分七个步骤: 1.点击文件--新建,新建一个500×500像素,背景为透明的文件,选择RGB颜色. 2.把前景色和文字颜色设置为正红(R为255,G和B为0). 3.在视图下拉菜单中选择标尺,将横. ...

  2. C&num;基础枚举的设计

    枚举分为:简单枚举和标记枚举(为了枚举值位操作) 标记枚举的用法:

  3. 关于Stringbulider类

    在使用String类构造一个字符串时,要给它分配足够的内存来保存字符串,但StringBuilder通常分配的内存会比需要的更多.开发人员可以选择显式指定StringBuilder要分配多少内存,但如 ...

  4. Spring4&period;14 事务异常 NoUniqueBeanDefinitionException&colon; No qualifying bean of type &lbrack;&period;&period;&period;&period;PlatformTransactionManager&rsqb;

    环境为Spring + Spring mvc + mybatis:其中Spring版本为4.1.4 spring配置文件: <?xml version="1.0" encod ...

  5. 电脑中dll文件丢失怎么恢复?

    DLL文件是Windows系统中的动态链接文件,我们在运行程序时都必须链接到dll文件,如果缺少了则无法正常运行,相信大家都会遇到dll文件缺失的情况,那么电脑中dll文件丢失怎么恢复?下面装机之家分 ...

  6. 【机器学习基础】对 softmax 和 cross-entropy 求导

    目录 符号定义 对 softmax 求导 对 cross-entropy 求导 对 softmax 和 cross-entropy 一起求导 References 在论文中看到对 softmax 和 ...

  7. 微信跳转ticket值怎么得到&quest;浏览器跳到微信&quest;哪里有微信跳转接口&quest;跳转功能能用多久&quest;

    目前很多实用微信跳转技术的电商朋友,网站文章头部或者文章中部出现了点击关注微信关注的二维码,用户点击进去直接跳转到微信内打开指定的二维码,识别即可关注,方便省事,比以往的一键复制—粘贴微信号,转化效果 ...

  8. ipod classic 检查硬盘方法

    长按(中间键+MENU)重启接着按(中键+左键)一直进入工程模式进入后顺序是:menu-IO-HARDDRIVE-HDSMARTDATA 就可以看到了. retracts--硬盘磁头非正常退回,比如硬 ...

  9. multiselect2side:jQuery多选列表框插件

    http://blog.csdn.net/rosanu_blog/article/details/8550723 http://www.bkjia.com/jQuery/449193.html &lt ...

  10. linux rename 和&quest;&quest;&quest;&quest;&quest;

    [root@ob2 mytmp]# ls01.txt  02.txt  03.txt  aa2.txt  aa.sh  aa.txt  tp_2017-09-143516.tar.gz  tt [ro ...