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 ...
随机推荐
- 射线与平面的相交检测(Ray-Plane intersection test)【转】
射线的定义 在欧几里德几何中,射线的定义是:直线上一点和它一旁的部分.由此可知,射线有两个性质,一是只有一个端点,二是一端无限延伸. 射线的参数方程 其中p0是射线的起点, u是射线的方向向量,t & ...
- [JS] 数据双向绑定原理
通常在前端开发过程中,经常遇到需要绑定两个甚至多个元素之间的值,比如将input的值绑定到一个h1上,改变input的值,h1的文字也自动更新. <h1 id="title" ...
- Struts2-057/CVE-2018-11776两个版本RCE漏洞分析(含EXP)
0x01 前言 2018年8月22日,Apache Strust2发布最新安全公告,Apache Struts2存在远程代码执行的高危漏洞(S2-057/CVE-2018-11776),该漏洞由Sem ...
- WPF ScrollViewer滚动条样式,适合触摸屏使用
触摸屏上客户要求滚动条宽度大些,方便手指上下滚动,之前在网上看了个,原文找不到了,代码记录下. 效果如下: <ControlTemplate x:Key="ScrollViewerCo ...
- C#Winfrom Listview数据导入Excel
需引用 public void ExportToExecl() { System.Windows.Forms.SaveFileDialog sfd = new SaveFileDialog(); sf ...
- Android Google Analytics
基础知识: 一个统计条目包含两类,一种是 screen,另一种是 event. Screen 包括 screen name. Event 包括 category,action,label 和 val ...
- Android 美学设计基础 <3>
本期接着对Android的美学设计的分享. 1.3 Light and shadows 光学与阴影 1.3.1 Light 在素材设计的环境中,我们会用虚拟的光来照亮UI界面.主灯光会产生尖锐,有方向 ...
- Apache Log4j配置说明
1.Log4j简介 Log4j是Apache的一个开源项目,它允许开发者以任意间隔输出日志信息.Log4j主要由三大类组件构成: 1)Logger-负责输出日志信息,并能够对日志信息进行分类筛选,即决 ...
- 双向一对一映射@OneToOne
双向一对一的实例我已经上传到GitHub,entrance项目上了,感兴趣的可以下载下来跑跑,这里讲两个在运行过程中遇到的问题. 问题一:上一篇博客的最后我留下了问题.一对一关联查询注解@OneToO ...
- 使用泛型SwingWorker与EDT事件分发线程保持通讯
为什么要使用SwingWorker 在swing开发中,如果一个应用程序,执行一些任务,需要大量的时间来完成,比如下载一个大文件或执行一个复杂的数据库查询. 我们假设这些任务是由用户使用一个按钮触发的 ...