POJ 1062 昂贵的聘礼(枚举限制条件——Dijkstra算法)
题目:
为了方便起见,我们把所有的物品从1开始进行编号,酋长的允诺也看作一个物品,并且编号总是1。每个物品都有对应的价格P,主人的地位等级L,以及一系列的替代品Ti和该替代品所对应的"优惠"Vi。如果两人地位等级差距超过了M,就不能"间接交易"。你必须根据这些数据来计算出探险家最少需要多少金币才能娶到酋长的女儿。
Input
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
题意描述:
输入等级限制rl,和物品件数
输入每件物品及其替代品
解题思路:
最短路问题,求花费的最少金币,另外需要的是要所有交易的物品的等级不能超过等级限制。刚开始以为只要交易的前一位和后一位不超过等级限制就行了,WA了两次,其实是探险家走的每一条成功路径上的所有物品任意两个之间均不能超过等级限制。
具体思路是枚举每件物品的等级,当做最小等级,那么在此前提下,所有和最小等级的差大于等级限制rl的和等级小于最小等级的物品都不能交易。遍历所有物品等级,在求最短路之前根据限制条件标记数组,求出众多最短路的最小值即可。
需要思考的是,dis数组中刚开始存储的就是各自的到达1号物品的花费,经过n次最短路的松弛,dis就是各自到达1的最短路了。
代码实现:
#include<stdio.h>
#include<string.h>
struct N
{
int p,r;
};
struct N w[];
int rl,n,e[][],book[],dis[];
int Dijkstra();
int inf=;
int main()
{
int i,j,t,k,l,ans,temp;
while(scanf("%d%d",&rl,&n) != EOF)
{
for(i=;i<=n;i++)
for(j=;j<=n;j++)
e[i][j]=inf;//i==j时也初始化为inf
for(i=;i<=n;i++)
{
scanf("%d%d%d",&w[i].p,&w[i].r,&t);
while(t--)
{
scanf("%d%d",&k,&l);
e[k][i]=l;//无向图
}
} ans=inf;
for(i=;i<=n;i++)
{
int ml =w[i].r;
for(j = ; j <= n; j ++)
{
if(w[j].r - ml > rl || ml > w[j].r)
book[j]=;
else
book[j]=;
}
temp = Dijkstra();
if(ans > temp)
ans=temp;//逻辑关系
}
printf("%d\n",ans);
}
return ;
}
int Dijkstra()
{
int i,j;
for(i=;i<=n;i++)
dis[i]=w[i].p;
for(i=;i<=n;i++)
{
int min = inf, k = -;
for(j = ; j <= n; j++)
{
if(!book[j] && dis[j] < min)
{//执行的是两条语句,要加括号
min = dis[j];
k = j;
}
}
book[k]=;
for(j=;j<=n;j++)
{
if(!book[j] && dis[j] > dis[k] + e[k][j])
dis[j] = dis[k] + e[k][j];
}
}
return dis[];
}
易错分析:
1、初始化地图时将i==j也初始化为无穷大,因为要求最少金币。
2、分清是无向图还是有向图,此题为有向图,因为交易是有方向的。
3、求最大或者最小时注意逻辑关系。
4、注意不要省括号,有时会更费时间去找错。
5、如果有限制条件,尽可能在标记数组中直接标记,在循环中限制出错率更高一些。
POJ 1062 昂贵的聘礼(枚举限制条件——Dijkstra算法)的更多相关文章
- POJ 1062 昂贵的聘礼(带限制条件的dijkstra)
题目网址:http://poj.org/problem?id=1062 题目: 昂贵的聘礼 Time Limit: 1000MS Memory Limit: 10000K Total Submis ...
- POJ - 1062 昂贵的聘礼(最短路Dijkstra)
昂贵的聘礼 Time Limit: 1000MS Memory Limit: 10000KB 64bit IO Format: %I64d & %I64u SubmitStatus Descr ...
- poj 1062 昂贵的聘礼 最短路 dijkstra
#include <cstdio> #include <cmath> #include <cstring> #include <ctime> #incl ...
- 最短路(Dijkstra) POJ 1062 昂贵的聘礼
题目传送门 /* 最短路:Dijkstra算法,首先依照等级差距枚举“删除”某些点,即used,然后分别从该点出发生成最短路 更新每个点的最短路的最小值 注意:国王的等级不一定是最高的:) */ #i ...
- POJ 1062 昂贵的聘礼(图论,最短路径)
POJ 1062 昂贵的聘礼(图论,最短路径) Description 年轻的探险家来到了一个印第安部落里.在那里他和酋长的女儿相爱了,于是便向酋长去求亲.酋长要他用10000个金币作为聘礼才答应把女 ...
- poj 1062 昂贵的聘礼 (dijkstra最短路)
题目链接:http://poj.org/problem?id=1062 昂贵的聘礼 Time Limit: 1000MS Memory Limit: 10000K Total Submission ...
- POJ 1062 昂贵的聘礼(Dijkstra)
题意 : 真真是做POJ第一次遇到中文题,好吧,虽然语言通了,我一开始也没看懂样例什么意思,题意的话就是说这个探险家想娶酋长的女儿,但是没有钱,酋长说他可以用祭司的水晶球或者皮袄来换取少花一部分钱,同 ...
- POJ - 1062 昂贵的聘礼 Dijkstra
思路:构造最短路模型,抽象出来一个源点,这个源点到第i个点的费用就是price[i],然后就能抽象出图来,终点是1. 任意两个人之间都有等级限制,就枚举所有最低等级限制,然后将不再区间[min_lev ...
- POJ 1062 昂贵的聘礼
C - 昂贵的聘礼 Time Limit:1000MS Memory Limit:10000KB 64bit IO Format:%I64d & %I64u Submit St ...
- POJ -1062 昂贵的聘礼(前向星 && SPFA)
版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/u013497151/article/details/30299671 题目链接:id=1062&qu ...
随机推荐
- Android中设置分割线
设置分隔线的方法一: 在需要设置分隔线的布局文件中加入如下代码: <View android:layout_width="fill_parent" andr ...
- Nodejs书写爬虫工具
看了几天的nodejs,的确是好用,全当是练手了,就写了一个爬虫工具. 爬虫思路都是一致的,先抓取页面数据,然后分析页面,获取到所需要的数据,最后获得这些数据,是写入到硬盘,还是显示到网页,自己看着办 ...
- Spring Boot 应用系列 3 -- Spring Boot 2 整合MyBatis和Druid,多数据源
本文演示多数据源(MySQL+SQL Server)的配置,并且我引入了分页插件pagehelper. 1. 项目结构 (1)db.properties存储数据源和连接池配置. (2)两个数据源的ma ...
- Spring Boot 2 实践记录之 MyBatis 集成的启动时警告信息问题
按笔者 Spring Boot 2 实践记录之 MySQL + MyBatis 配置 中的方式,如果想正确运行,需要在 Mapper 类上添加 @Mapper 注解. 但是加入此注解之后,启动时会出现 ...
- spring boot 使用 HandlerInterceptor
# 背景 在实际项目中,接口出于安全考虑,都会有验签的计算.目前接触的项目来看基本都是时间戳+干扰因子 然后md5计算的方式.现在学习,写一个简单demo, 其实如果不引入拦截器的话,验签计算全部在c ...
- 如何在centos下配置redis开机自启动
2014/11/10补充:其实在redis的下载包中就包含了官方自带的启动脚本,路径在/redis-stable/utils/redis_init_script.在utils目录下也有安装redis- ...
- Python廖雪峰学习笔记——操作文件和目录
查看当前目录的绝对路径: >>>os.path.abspath('.') # 在某个目录下创建一个新目录, # 首先把新目录的完整路径表示出来: >>> os.pa ...
- $_REQUEST预定义变量
1,$_REQUEST接收$_GET,$_POST,$_COOKIE数据,因此这三种方式都可以攻击$_REQUEST方式,这种方式不安全,不建议使用$_REQUEST. 2,如果不知道get或post ...
- 创建一个vue项目,vue-cli,webpack
,换成淘宝源: npm config set registry https://registry.npm.taobao.org/ 检查是否修改成功 npm config get registry ,安 ...
- 微信小程序与vueJs的异同
简而言之,所有的框架都是建立在原生javascript基础之上的,所以对于有一定js基础的同学来说,各种框架都是比较容易入手的,但不同的框架之间又有一定的差别,有时候切换使用时就会掉入坑了. 一.微信 ...