POJ 1066 昂贵的聘礼
Description
在那里他和酋长的女儿相爱了,于是便向酋长去求亲。酋长要他用10000个金币作为聘礼才答应把女儿嫁给他。探险家拿不出这么多金币,便请求酋长减少要求。酋长说:"嗯,假设你能够替我弄到大祭司的皮袄,我能够仅仅要8000金币。假设你能够弄来他的水晶球。那么仅仅要5000金币即可了。
"探险家就跑到大祭司那里。向他要求皮袄或水晶球,大祭司要他用金币来换,或者替他弄来其它的东西,他能够减少价格。探险家于是又跑到其它地方,其它人也提出了相似的要求,或者直接用金币换,或者找到其它东西就能够减少价格。
只是探险家不是必需用多样东西去换一样东西,由于不会得到更低的价格。探险家如今非常须要你的帮忙。让他用最少的金币娶到自己的心上人。另外他要告诉你的是,在这个部落里,等级观念十分森严。
地位差距超过一定限制的两个人之间不会进行不论什么形式的直接接触,包含交易。
他是一个外来人。所以能够不受这些限制。可是假设他和某个地位较低的人进行了交易,地位较高的的人不会再和他交易。他们觉得这样等于是间接接触,反过来也一样。因此你须要在考虑全部的情况以后给他提供一个最好的方案。
为了方便起见,我们把全部的物品从1開始进行编号,酋长的允诺也看作一个物品,而且编号总是1。
每一个物品都有相应的价格P,主人的地位等级L,以及一系列的替代品Ti和该替代品所相应的"优惠"Vi。假设两人地位等级差距超过了M,就不能"间接交易"。
你必须依据这些数据来计算出探险家最少须要多少金币才干娶到酋长的女儿。
Input
每一个物品的描写叙述开头是三个非负整数P、L、X(X < N)。依次表示该物品的价格、主人的地位等级和替代品总数。
接下来X行每行包含两个整数T和V。分别表示替代品的编号和"优惠价格"。
Output
Sample Input
1 4
10000 3 2
2 8000
3 5000
1000 2 1
4 200
3000 2 1
4 200
50 2 0
Sample Output
5250
思路:从冒险家出发建图,出发节点标为0 。 每一个物品与它的替代品构成有向边,即替代品指向该物品,终于找出到1这个物品的最短路。
本题比較困难的地方就是它限制了等级。也是研究了网上的代码才有了思路。枚举每一个物品的主人的等级并设为最大的等级 设为maxlv,最小等级则为minlv=maxlv-m,那么其余的物品的主人的等级必须要大于maxlv。仅仅计算这些合法的物品就能够了,每次枚举都更新终于结果。
#include<stdio.h>
#include<string.h>
const int INF=10000000;
int n,m,d[105],w[105][105],v[105],lv[105],use[105];
int Min(int a,int b)
{
return a<b?
a:b;
}
int dijkstra() //最短路算法
{
memset(v,0,sizeof(v));
for(int i=1;i<=n;i++) d[i]=INF;d[0]=0;
for(int i=0;i<=n;i++) {
int x,m=INF;
for(int y=0;y<=n;y++) if(!use[y] && !v[y] && d[y]<=m) m=d[x=y]; //use[]记录是否为等级合法的物品。
v[x]=1;
if(x==1) break;
for(int y=0;y<=n;y++) if(!use[y])
d[y]=Min(d[y] , d[x]+w[x][y]);
}
return d[1];
}
int main()
{
while(~scanf("%d%d",&m,&n)) {
int t,tmp1,tmp2,i,j,ans=INF;
for(i=0;i<=n;i++)
for(j=0;j<=n;j++)
w[i][j]=INF;
for(i=1;i<=n;i++) {
scanf("%d%d%d",&w[0][i],&lv[i],&t);
for(j=1;j<=t;j++) {
scanf("%d%d",&tmp1,&tmp2);
w[tmp1][i]=tmp2;
}
}
for(i=1;i<=n;i++) { //枚举每一个物品,并求一次在该物品的主人等级最高的前提下的最短路。
这是本题比較困难的地方
int maxlv=lv[i],minlv=lv[i]-m,tmp;
memset(use,0,sizeof(use));
for(j=1;j<=n;j++) {
if(lv[j]>maxlv || lv[j]<minlv) use[j]=1;
}
tmp=dijkstra();
if(tmp<ans) ans=tmp;
}
printf("%d\n",ans);
}
return 0;
}POJ 1066 昂贵的聘礼的更多相关文章
- 最短路(Dijkstra) POJ 1062 昂贵的聘礼
题目传送门 /* 最短路:Dijkstra算法,首先依照等级差距枚举“删除”某些点,即used,然后分别从该点出发生成最短路 更新每个点的最短路的最小值 注意:国王的等级不一定是最高的:) */ #i ...
- POJ 1062 昂贵的聘礼(图论,最短路径)
POJ 1062 昂贵的聘礼(图论,最短路径) Description 年轻的探险家来到了一个印第安部落里.在那里他和酋长的女儿相爱了,于是便向酋长去求亲.酋长要他用10000个金币作为聘礼才答应把女 ...
- POJ 1062 昂贵的聘礼
C - 昂贵的聘礼 Time Limit:1000MS Memory Limit:10000KB 64bit IO Format:%I64d & %I64u Submit St ...
- poj 1062 昂贵的聘礼 (dijkstra最短路)
题目链接:http://poj.org/problem?id=1062 昂贵的聘礼 Time Limit: 1000MS Memory Limit: 10000K Total Submission ...
- 最短路POJ 1062 昂贵的聘礼
C - 昂贵的聘礼 Time Limit:1000MS Memory Limit:10000KB 64bit IO Format:%I64d & %I64u Submit St ...
- POJ 1062 昂贵的聘礼(带限制条件的dijkstra)
题目网址:http://poj.org/problem?id=1062 题目: 昂贵的聘礼 Time Limit: 1000MS Memory Limit: 10000K Total Submis ...
- POJ 1062 昂贵的聘礼 (最短路)
昂贵的聘礼 题目链接: http://acm.hust.edu.cn/vjudge/contest/122685#problem/M Description 年轻的探险家来到了一个印第安部落里.在那里 ...
- POJ 1062 昂贵的聘礼(最短路中等题)
昂贵的聘礼 Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 51879 Accepted: 15584 Descripti ...
- POJ -1062 昂贵的聘礼(前向星 && SPFA)
版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/u013497151/article/details/30299671 题目链接:id=1062&qu ...
随机推荐
- 记一次webapi传参数的问题
.net小白一枚,经过了几个小时的研究,由于错误的写法导致后台始终接受不到前台传递过来的参数.首先看看控制器的参数 public Core.MVC.ServiceResult<DTO.Out.M ...
- java数组创建
java数组创建:int[] number = new int[10]; int[]:表明这是一个数组 new int[10]:给前面的数组类型的number变量分配10个int类型的空间大小
- Java - LinkedList源码分析
java提高篇(二二)---LinkedList 一.概述 LinkedList与ArrayList一样实现List接口,只是ArrayList是List接口的大小可变数组的实现,LinkedList ...
- Java - 生产者消费者问题
Java多线程系列--“基础篇”11之 生产消费者问题 概要 本章,会对“生产/消费者问题”进行讨论.涉及到的内容包括:1. 生产/消费者模型2. 生产/消费者实现 转载请注明出处:http://ww ...
- 【10-2】复杂业务状态的处理(从状态者模式到FSM)
一.概述 我们平常在开发业务模块时,经常会遇到比较复杂的状态转换.比如说用户可能有新注册.实名认证中.已实名认证.禁用等状态,支付可能有等待支付.支付中.已支付等状态.OA系统里的状态处理就更多了. ...
- Linux常用基本命令[find]用法(1)
find是个很强大的命令,用法很多. 作用:查找目录下的文件,同时也可以调用其他命令执行相应的操作 用法: find [选项] [路径][操作语句] find [-H] [-L] [-P] [-D d ...
- 在微信小程序中引入 Iconfont 阿里巴巴图标库
小程序的代码包不能超过4M,为了压缩代码包的大小,可以通过第三方链接引入图标资源 Iconfont 无疑是最常用的第三方图标库,这里介绍一下在微信小程序引入 Iconfont 的方法 一.下载图标 首 ...
- 设计模式(17)--Mediator(中介者模式)行为型
作者QQ:1095737364 QQ群:123300273 欢迎加入! 1.模式定义: 用一个中介者对象封装一系列的对象交互,中介者使各对象不需要显示地相互作用,从而使耦合松散,而且可以 ...
- python乐观锁、悲观锁
二.乐观锁总是认为不会产生并发问题,每次去取数据的时候总认为不会有其他线程对数据进行修改,因此不会上锁,但是在更新时会判断其他线程在这之前有没有对数据进行修改 三.悲观锁总是假设最坏的情况,每次取数据 ...
- 洛谷P3924 康娜的线段树(期望 前缀和)
题意 题目链接 Sol 思路就是根据期望的线性性直接拿前缀和算贡献.. 这题输出的时候是不需要约分的qwq 如果你和我一样为了AC不追求效率的话直接#define int __int128就行了.. ...