http://codevs.cn/problem/1324/

  • 题目大意

    一个部落,你能够和社会地位等级的极差不大于M的全部人交易。你能够拿金币直接从一个人手里买东西,也能够从别人那里买到那个人想要的东西来获取减价。

    问终于从酋长那里“买”到你心仪的“东西”的最小代价。

  • 题解

    把自己作为起点。向每个物品连边权为这件物品原价的有向边。然后假设买物品i会使物品j降价,那么连一条从i到j边权为降价后的价格的有向边。然后枚举包含了酋长等级的全部等级范围,从自己到酋长的“东西”跑仅仅经过当前等级范围同意的最短路,再取最小值就可以。

    多组数据处理时要把原图清干净。

  • Code

#include <cstdio>
#include <algorithm>
#include <queue>
#include <vector>
#include <cstring>
using namespace std;
const int maxn = 100000, nil = 0, oo = 1000000000;
int M, N, S, T, ans;
int e, nxt[maxn], u[maxn], v[maxn], w[maxn], pnt[150];
int d[150];
bool vis[150];
struct things
{
int n, p, m;
things(int n = 0, int p = 0, int m = 0) :n(n), p(p), m(m) {}
}sth[150];
vector <things> rep[150];
struct node
{
int n, dis;
node(int n = 0, int dis = 0) :n(n), dis(dis) {}
bool operator < (const node& b) const
{
return dis > b.dis;
}
};
void addedge(int a, int b, int c)
{
u[++e] = a; v[e] = b; w[e] = c;
nxt[e] = pnt[a]; pnt[a] = e;
}
void init()
{
int P, L, X, Tt, V;
e = 0; ans = oo;
memset(nxt, 0, sizeof(nxt));
memset(pnt, 0, sizeof(pnt));
memset(u, 0, sizeof(u));
memset(v, 0, sizeof(v));
memset(w, 0, sizeof(w));
for(int i = 0; i < 150; ++i)
{
sth[i] = things();
rep[i].clear();
}
for(int i = 1; i <= N; ++i)
{
scanf("%d%d%d", &P, &L, &X);
sth[i] = things(i, P, L);
for(int j = 1; j <= X; ++j)
{
scanf("%d%d", &Tt, &V);
rep[i].push_back(things(Tt, V));
}
}
S = 0; T = 1;
for(int i = 1; i <= N; ++i)
{
addedge(S, i, sth[i].p);
for(int j = 0; j < rep[i].size(); ++j)
{
addedge(rep[i][j].n, i, rep[i][j].p);
addedge(S, rep[i][j].n, sth[rep[i][j].n].p);
}
}
}
void getSSSP(int minM, int maxM)
{
memset(d, 0x3f, sizeof(d));
memset(vis, 0, sizeof(vis));
priority_queue <node> Q;
d[S] = 0;
Q.push(node(S, 0));
while(!Q.empty())
{
node t = Q.top();
Q.pop();
vis[t.n] = true;
for(int j = pnt[t.n]; j != nil; j = nxt[j])
{
if((!vis[v[j]]) && (sth[v[j]].m >= minM) && (sth[v[j]].m <= maxM) && (d[v[j]] > t.dis + w[j]))
{
d[v[j]] = t.dis + w[j];
Q.push(node(v[j], d[v[j]]));
}
}
}
}
void work()
{
for(int i = sth[T].m - M; i <= sth[T].m; ++i)
{
getSSSP(i, i + M);
ans = min(ans, d[T]);
}
printf("%d\n", ans);
}
int main()
{
while(scanf("%d%d", &M, &N) == 2)
{
init();
work();
}
return 0;
}
  • 总结

    题见得多了,建图的感觉自然就有了。

ZJOI2002昂贵的聘礼题解的更多相关文章

  1. ZJOI2002 昂贵的聘礼

    题目描述 Description 年轻的探险家来到了一个印第安部落里.在那里他和酋长的女儿相爱了,于是便向酋长去求亲.酋长要他用10000个金币作为聘礼才答应把女儿嫁给他.探险家拿不出这么多金币,便请 ...

  2. POJ 1062 昂贵的聘礼 (最短路)

    昂贵的聘礼 题目链接: http://acm.hust.edu.cn/vjudge/contest/122685#problem/M Description 年轻的探险家来到了一个印第安部落里.在那里 ...

  3. POJ1062:昂贵的聘礼(dfs)

    昂贵的聘礼 Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 58108   Accepted: 17536 题目链接:http ...

  4. POJ1062昂贵的聘礼[最短路建模]

    昂贵的聘礼 Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 45892   Accepted: 13614 Descripti ...

  5. 昂贵的聘礼(dijkstra)

    昂贵的聘礼 Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 38549   Accepted: 11158 Descripti ...

  6. POJ 1062 昂贵的聘礼

    C - 昂贵的聘礼 Time Limit:1000MS     Memory Limit:10000KB     64bit IO Format:%I64d & %I64u Submit St ...

  7. 最短路(Dijkstra) POJ 1062 昂贵的聘礼

    题目传送门 /* 最短路:Dijkstra算法,首先依照等级差距枚举“删除”某些点,即used,然后分别从该点出发生成最短路 更新每个点的最短路的最小值 注意:国王的等级不一定是最高的:) */ #i ...

  8. Poj OpenJudge 百练 1062 昂贵的聘礼

    1.Link: http://poj.org/problem?id=1062 http://bailian.openjudge.cn/practice/1062/ 2.Content: 昂贵的聘礼 T ...

  9. POJ1062昂贵的聘礼(dijkstra)

    昂贵的聘礼 题目大意是说有N个物品,每个物品都有自己的价格,但同时某些物品也可以由其他的(可能不止一个)替代品,这些替代品的价格比较“优惠”,问怎么样选取可以让你的花费最少来购买到物品1 由于有N个物 ...

随机推荐

  1. VM虚拟机全屏显示

    在虚拟机中使用全屏界面会有更强的用户体验.在编辑该文章的时候就是在使用虚拟机windows2008 R2系统.我的笔记本是苹果双系统.虚拟机安装在win7 64位系统下 1.首先查看主机的屏幕分辨率 ...

  2. poj Transferring Sylla(怎样高速的推断一个图是否是3—连通图,求割点,割边)

    Transferring Sylla 首先.什么是k连通图? k连通图就是指至少去掉k个点使之不连通的图. 题目: 题目描写叙述的非常裸.就是给你一张图要求你推断这图是否是3-连通图. 算法分析: / ...

  3. 网页中插入javascript的几种方法

    网页中插入javascript的方法常见的有两种: 一.直接使用html标记 JavaScript 可以出现在 html的任意地方.使用标记<script>…</script> ...

  4. ElasticSearch vs 关系型数据库

    它们之间的关系,如下图所示.

  5. 错误日志写入到本地磁盘(lock 队列)

    今天照常在b站上看看编程:看到有讲错误日志处理的,自己没写过日志,就看看了看: 主要是在讲的时候牵扯到了队列和lock的知识点:这方面知识自己了解的更少,那就记录一下.

  6. 2017国家集训队作业[arc076d/f][Exhausted?]

    2017国家集训队作业[arc076d/f][Exhausted?] 题意: ​ 有\(N\)个人,\(M\)把椅子,给出\(...L_i.R_i\)表示第\(i\)个人可以选择编号为\(1\sim ...

  7. POJ——T 3461 Oulipo

    http://poj.org/problem?id=3461 Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 42698   ...

  8. 经验之谈—让你看明确block

    事实上我感觉不常常使用block的朋友.对block应该是比較陌生的,那么如今我们来扒开block的真面目,看看block的本质 普通的局部变量.block内部仅仅会引用它初始的值(block定义那一 ...

  9. HASH Partitioning--转载

    原文地址:https://dev.mysql.com/doc/refman/5.1/en/partitioning-hash.html HASH Partitioning [+/-] 18.2.3.1 ...

  10. c#的中英文混合字符串截取

    public class StringHelper     {         public static string GetSubString(string str, int len)       ...