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 ...
随机推荐
- 在.net中序列化读写xml方法的总结--转载过来学习学习
原文章地址:http://www.cnblogs.com/fish-li/archive/2013/05/05/3061816.html 首先做个大概的总结,XML包括的元素有XmlElement,X ...
- Hibernate映射 --- 自身跟自身的一对多关联
自身跟自身的一对多关联 什么时候会出现自身一对多关系呢?下面举个例子. 淘宝店里商品分类,一级分类:家用电器,个人化妆,运动户外等 家用电器下面二级分类:大家电,生活电器,厨房电器等 二级分类大家 ...
- 多线程系列(3)任务Task
虽然使用线程池ThreadPool让我们使用多线程变得容易,但是因为是由系统来分配的,如果想对线程做精细的控制就不太容易了,比如某个线程结束后执行一个回调方法.恰好Task可以实现这样的需求.这篇文章 ...
- Android四大组件framework层
activity https://www.kancloud.cn/alex_wsc/android-deep2/413484 当前Activity Activity向AMS发送StartActivit ...
- 数据库导入导出expdp,impdp
数据库操作 (1)数据库导入导出expdp,impdp 在导入导出数据库的时候,经常会用到exp和imp,在数据量小的情况下可以随意使用,但是当数据量大,表中数据有百万,千万条的时候,就要等好久好久好 ...
- 'QuerySet' object has no attribute '_meta'
'QuerySet' object has no attribute '_meta' 对象列表没有'_meta'属性 单独的对象才有, 忘记加first了 edit_obj = models.Role ...
- JS之ClassName属性使用
一.style与className属性的对比 在前面的style属性学习中,知道了通过style属性可以控制元素的样式,从而实现了行为层通过DOM的style属性去干预变现层显示的目地,但是这种就是不 ...
- jq插件写法
如今做web开发,jQuery 几乎是必不可少的,同时jquery插件也是不断的被大家所熟知,以及运用.最近在搞这个jquery插件,发现它的牛逼之处,所以讲一讲jQuery插件的写法以及使用 (f ...
- 【node+小程序+web端】简单的websocket通讯
[node+小程序+web端]简单的websocket通讯 websoket是用来做什么的? 聊天室 消息列表 拼多多 即时通讯,推送, 实时交互 websoket是什么 websocket是一个全新 ...
- Windows7安装nginx后,'nginx -t -c nginx.conf' 命令出现 “could not open error log file: CreateFile() "logs/error.log" failed” 错误的原因
网上搜索安装nginx的方法,按照步骤在 http://nginx.org/en/download.html 下载了安装包,并配置了conf/nginx.conf,将nginx的根目录添加进了环境变量 ...