昂贵的聘礼 - poj 1062 (Dijkstra+枚举)

Time Limit: 1000MS   Memory Limit: 10000K
Total Submissions: 39976   Accepted: 11596

Description

年轻的探险家来到了一个印第安部落里。在那里他和酋长的女儿相爱了,于是便向酋长去求亲。酋长要他用10000个金币作为聘礼才答应把女儿嫁给他。探险家拿不出这么多金币,便请求酋长降低要求。酋长说:"嗯,如果你能够替我弄到大祭司的皮袄,我可以只要8000金币。如果你能够弄来他的水晶球,那么只要5000金币就行了。"探险家就跑到大祭司那里,向他要求皮袄或水晶球,大祭司要他用金币来换,或者替他弄来其他的东西,他可以降低价格。探险家于是又跑到其他地方,其他人也提出了类似的要求,或者直接用金币换,或者找到其他东西就可以降低价格。不过探险家没必要用多样东西去换一样东西,因为不会得到更低的价格。探险家现在很需要你的帮忙,让他用最少的金币娶到自己的心上人。另外他要告诉你的是,在这个部落里,等级观念十分森严。地位差距超过一定限制的两个人之间不会进行任何形式的直接接触,包括交易。他是一个外来人,所以可以不受这些限制。但是如果他和某个地位较低的人进行了交易,地位较高的的人不会再和他交易,他们认为这样等于是间接接触,反过来也一样。因此你需要在考虑所有的情况以后给他提供一个最好的方案。 
为了方便起见,我们把所有的物品从1开始进行编号,酋长的允诺也看作一个物品,并且编号总是1。每个物品都有对应的价格P,主人的地位等级L,以及一系列的替代品Ti和该替代品所对应的"优惠"Vi。如果两人地位等级差距超过了M,就不能"间接交易"。你必须根据这些数据来计算出探险家最少需要多少金币才能娶到酋长的女儿。

Input

输入第一行是两个整数M,N(1 <= N <= 100),依次表示地位等级差距限制和物品的总数。接下来按照编号从小到大依次给出了N个物品的描述。每个物品的描述开头是三个非负整数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这题可以利用Dijkstra求最短路径得出,例子中的图可以用下图表示:

关于等级限制,可以利用枚举的方法,例如酋长等级为l,等级限制为m,则可以枚举[l-m,l]一直到[l,l+m]
 1 #include <iostream>
 2 #include<limits.h>
 3 #include<algorithm>
 4 using namespace std;
 5 int map[101][101],vis[101],level[101],dis[101];
 6 int level_gap,num;
 7 int min_cost;
 8 int Dijkstra(){
 9     for(int i=1;i<=num;i++){
10         dis[i]=map[0][i];
11     }
12 for(int i=0;i<=num;i++){
13     int min_dis=INT_MAX;
14     int ind=0;
15     for(int j=0;j<=num;j++){
16         if((!vis[j])&&(dis[j]<min_dis)){
17             min_dis=dis[j];
18             ind=j;
19         }
20     }
21     vis[ind]=1;
22     if(min_dis==INT_MAX)
23         break;
24     for(int j=0;j<=num;j++){
25         if(!vis[j]&&map[ind][j]!=INT_MAX){
26             if(map[ind][j]+dis[ind]<dis[j]){
27                 dis[j]=dis[ind]+map[ind][j];
28             }
29         }
30     }
31 }
32 return dis[1];
33 }
34 int main() {
35
36     cin>>level_gap>>num;
37     for(int i=0;i<=num;i++){
38         for(int j=0;j<=num;j++){
39             map[i][j]=INT_MAX;
40         }
41     }
42     dis[0]=0;
43     min_cost=INT_MAX;
44     for(int i=1;i<=num;i++){
45         int value,lev,rep_num;
46         cin>>value>>lev>>rep_num;
47         map[0][i]=value;
48         level[i]=lev;
49         for(int j=0;j<rep_num;j++){
50             int n;
51             cin>>n>>value;
52             map[n][i]=value;
53         }
54     }
55     for(int i=level[1]-level_gap;i<=level[1];i++){
56         for(int j=1;j<=num;j++){
57             if(level[j]>=i&&level[j]<=i+level_gap){
58                 vis[j]=0;
59             }else{
60                 vis[j]=1;
61             }
62             vis[0]=1;
63         }
64         min_cost=min(min_cost,Dijkstra());
65     }
66     cout<<min_cost<<endl;
67     return 0;
68 }
				
时间: 2024-10-09 06:48:42

昂贵的聘礼 - poj 1062 (Dijkstra+枚举)的相关文章

昂贵的聘礼 poj 1062 Dijkstra

中文题,题意就不多说了,讲讲思路吧,先根据题意构图,与普通最短路不同的是这一题加了一个Rank,每个点都有一个Rank,题目要求最短路径上的点的Rank的最大差值在 M范围内,Dijkstra判断条件时加上Rank约束就行了.我没有添加汇点直接写的,另贴上别人添加汇点的写法. 我的代码: #include <iostream> #include <cstdio> #include <cstring> #include <algorithm> #include

POJ 1062 dijkstra + 枚举

这题从下午七点做到晚上的九点半,才做出来. 题意,有一个人A,要去人B那里买东西,人B说了一个价格,然后说如果你能把人C的东西弄来,再加上一部分钱(比直接买人B东西的价格少),也能买到. 于是人A又去了人C那里,人C说了同上的话.依次类推. 但是这个交易圈子里有个规定,就是每个人都有一个等级,如果两个人相差k个等级以上,是不能产生直接或者间接交易的. 问最后你一定要买到人A的东西,最少要多少钱. 分析,分析过后,可以通过交易关系,A需要B的东西,将一条边由B连上A,建立有向图.如果没有等级制度,

昂贵的聘礼 POJ - 1062

#include<iostream> #include<queue> #include<cstring> using namespace std; const int N=1e6+10,INF=0x3f3f3f3f; int h[N],ne[N],e[N],w[N],idx; int dist[N]; bool st[N]; int n,m,s=0; int grade[N]; void add(int a,int b,int c) { e[idx]=b; w[idx]

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

昂贵的聘礼 Time Limit: 1000MS Memory Limit: 10000KB 64bit IO Format: %I64d & %I64u SubmitStatus Description 年轻的探险家来到了一个印第安部落里.在那里他和酋长的女儿相爱了,于是便向酋长去求亲.酋长要他用10000个金币作为聘礼才答应把女儿嫁给他.探险家拿不出这么多金币,便请求酋长降低要求.酋长说:"嗯,如果你能够替我弄到大祭司的皮袄,我可以只要8000金币.如果你能够弄来他的水晶球,那么只要

poj 1062 昂贵的聘礼 最短路 dijkstra

#include <cstdio> #include <cmath> #include <cstring> #include <ctime> #include <iostream> #include <algorithm> #include <set> #include <vector> #include <sstream> #include <queue> #include <t

POJ 1062 昂贵的聘礼(带限制条件的dijkstra)

题目网址:http://poj.org/problem?id=1062 题目: 昂贵的聘礼 Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 49916   Accepted: 14961 Description 年轻的探险家来到了一个印第安部落里.在那里他和酋长的女儿相爱了,于是便向酋长去求亲.酋长要他用10000个金币作为聘礼才答应把女儿嫁给他.探险家拿不出这么多金币,便请求酋长降低要求.酋长说:"嗯,如果你能够替我弄到

poj 1062 昂贵的聘礼 (dijkstra最短路)

题目链接:http://poj.org/problem?id=1062 昂贵的聘礼 Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 36799   Accepted: 10616 Description 年轻的探险家来到了一个印第安部落里.在那里他和酋长的女儿相爱了,于是便向酋长去求亲.酋长要他用10000个金币作为聘礼才答应把女儿嫁给他.探险家拿不出这么多金币,便请求酋长降低要求.酋长说:"嗯,如果你能够替我弄到大祭司的

poj 1062 昂贵的聘礼 Dijkstra算法,中等难度,,,一道让我累觉不爱的题目

昂贵的聘礼 Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 38474   Accepted: 11132 Description 年轻的探险家来到了一个印第安部落里.在那里他和酋长的女儿相爱了,于是便向酋长去求亲.酋长要他用10000个金币作为聘礼才答应把女儿嫁给他.探险家拿不出这么多金币,便请求酋长降低要求.酋长说:"嗯,如果你能够替我弄到大祭司的皮袄,我可以只要8000金币.如果你能够弄来他的水晶球,那么只要5000

poj 1062 昂贵的聘礼 [dijkstra]

昂贵的聘礼 Description 年轻的探险家来到了一个印第安部落里.在那里他和酋长的女儿相爱了,于是便向酋长去求亲.酋长要他用10000个金币作为聘礼才答应把女儿嫁给他.探险家拿不出这么多金币,便请求酋长降低要求.酋长说:"嗯,如果你能够替我弄到大祭司的皮袄,我可以只要8000金币.如果你能够弄来他的水晶球,那么只要5000金币就行了."探险家就跑到大祭司那里,向他要求皮袄或水晶球,大祭司要他用金币来换,或者替他弄来其他的东西,他可以降低价格.探险家于是又跑到其他地方,其他人也提出