昂贵的聘礼

Time Limit : 2000/1000ms (Java/Other)   Memory Limit : 20000/10000K (Java/Other)
Total Submission(s) : 14   Accepted Submission(s) : 3
Problem 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算法,经典算法,和prime算法极为相似,将图中的点分成两个集合,A和B,起初A里面只包含源点S,B中是剩余的点,核心思想是:1,将B中与满足条件的点加入到A中(满足条件的点对于prime算法来说是B中与集合A距离最短的点,对于Dijksttra算法来说是B中到源点S距离最短的点。),记为P,并把P从B中去掉。2,更新:更新B中所有点到集合A(或源点S)的最近距离,每找到一个P就执行一次。循环执行1,2步骤,直到找不到满足条件的P点才结束。由于在P之前的加入到A 中的点都已将B 中的点更新过,因此只有刚加进来的P点才有可能更新B中点到A的最短距离,所有只需要对P点就行考察就行。

对于本题而言,关键点在于如何建图,另外由于有等级差距限制,需要枚举所有可能的等级。

数据结构:点较少时用邻接矩阵,数据较大时使用链式前向星。

 int map[MAX][MAX],vis[MAX],dist[MAX];
memset(vis,,sizeof(vis));
void Dijkstra()          //求单源最短路径;
{
for(i = ;i <= n;i ++)
{
min = << ;
k = ;
for(j = ;i <= n;j ++)
{
if(!vis[j] && min > dist[j])
{
min = dist[j];
k = j;
}
}
if(k == )
return ;
vis[k] = ;
for(j = ;j <= n;j ++)
{
if(!vis[j] && dist[j] > dist[k]+map[k][j])
dist[j] = dist[k]+map[k][j];
}
}
return ;
}//End of function; void prime()        //求最小生成树;
{
for(i = ;i <= n;i ++)
{
min = << ;
k = ;
for(j =;j <=n;j ++)
{
if(!vis[j] && min > dist[j])
{
min = dist[j];
k = j;
}
}
if(k == )
return ;
vis[k] = ;
for(j = ;j <= n;j ++)
{
if(!vis[j] && dist[j] > map[k][j])
dist[j] = map[k][j];
}
}
return ;
}//End of function;

AC代码:

 #include<stdio.h>
#include<stdlib.h>
#include<string.h>
int dist[],map[][];
int vis[],rank[],n,m;
void init1()
{
int i,j;
for(i = ;i <= n+;i ++)
{
for(j = ;j <= n+;j ++)
{
map[i][j] = << ;
}
}
return ;
} void init2()
{
int i;
for(i = ;i <= n+;i ++)
dist[i] = map[n+][i];
return ;
} void Dijkstra(int r)
{
int i,j,k,min;
for(i = ;i <= n;i ++)
{
if((rank[i]-r) < -m || (rank[i]-r) > m || rank[i] < r)
vis[i] = ;
}
for(i = ;i <= n;i ++)
{
min = << ;
k = -;
vis[n+] = ;
for(j = ;j <= n+;j ++)
{
if(!vis[j] && min > dist[j])
{
min = dist[j];
k = j;
}
}
if(k == -)
return ;
vis[k] = ;
for(j = ;j <= n;j ++)
{
if(!vis[j] && dist[j] > dist[k]+map[k][j])
dist[j] = dist[k]+map[k][j];
}
}
return ;
} int main(void)
{
int i,sum;
int p,l,x,t,v;
//freopen("in.c","r",stdin);
//freopen("re.c","w",stdout);
while(~scanf("%d%d",&m,&n))
{
init1();
sum = << ;
for(i = ;i <= n;i ++)
{
scanf("%d%d%d",&p,&l,&x);
map[n+][i] = p;
rank[i] = l;
while(x--)
{
scanf("%d%d",&t,&v);
map[t][i] = v;
}
}
for(i = rank[]-m;i <= rank[]+m;i ++)
{
init2();
memset(vis,,sizeof(vis));
Dijkstra(i);
if(sum > dist[])
sum = dist[];
}
printf("%d\n",sum);
}
return ;
}

昂贵的聘礼--POJ1062的更多相关文章

  1. M - 昂贵的聘礼 - poj1062

    Description 年轻的探险家来到了一个印第安部落里.在那里他和酋长的女儿相爱了,于是便向酋长去求亲.酋长要他用10000个金币作为聘礼才答应把女儿嫁给他.探险家拿不出这么多金币,便请求酋长降低 ...

  2. 昂贵的聘礼---poj1062(最短路)

    题目链接:http://poj.org/problem?id=1062 题意很清楚: 可以虚拟一个起点0,由于存在等级关系,所以可以枚举等级,然后把各种关系建立边,然后计算0到1的距离即可,去最小值即 ...

  3. [poj1062]昂贵的聘礼_最短路_离散化

    昂贵的聘礼 poj-1062 题目大意:原文链接?不是英文题,自己看 注释:$1\le N \le 100$. 想法:开始的想法有些过于简单,因为落下了一个条件:就是等级限制是一条路径上的任意两点而不 ...

  4. POJ1062昂贵的聘礼[最短路建模]

    昂贵的聘礼 Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 45892   Accepted: 13614 Descripti ...

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

    POJ-1062 昂贵的聘礼:http://poj.org/problem?id=1062 题意: 有一个人要到1号点花费最少的钱,他可以花费一号点对应的价格,也可以先买下其他一些点,使得费用降低. ...

  6. POJ1062昂贵的聘礼(dijkstra)

    昂贵的聘礼 题目大意是说有N个物品,每个物品都有自己的价格,但同时某些物品也可以由其他的(可能不止一个)替代品,这些替代品的价格比较“优惠”,问怎么样选取可以让你的花费最少来购买到物品1 由于有N个物 ...

  7. POJ1062 昂贵的聘礼 【DFS】

    昂贵的聘礼 Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 37475   Accepted: 10816 Descripti ...

  8. POJ1062昂贵的聘礼(经典) 枚举区间 +【Dijkstra】

    <题目链接>                   昂贵的聘礼 Description 年轻的探险家来到了一个印第安部落里.在那里他和酋长的女儿相爱了,于是便向酋长去求亲.酋长要他用1000 ...

  9. POJ1062:昂贵的聘礼(dfs)

    昂贵的聘礼 Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 58108   Accepted: 17536 题目链接:http ...

随机推荐

  1. iOS 获取当前媒体音量

    #import <AVFoundation/AVAudioSession.h> AVAudioSession *audioSession = [AVAudioSession sharedI ...

  2. Java实战之01Struts2-01简介及环境搭建

    一.Struts2简介 1.Struts2概述 Struts2是Apache发行的MVC开源框架.注意:它只是表现层(MVC)框架. 2.Struts2的来历 Struts1:也是apache开发的一 ...

  3. Linux apt-get error

    csh@csh-laptop:~/ejabberd-15.03$ sudo apt-get install mysqlReading package lists... DoneBuilding dep ...

  4. _itoa_s, _i64toa_s, _ui64toa_s, _itow_s, _i64tow_s, _ui64tow_s

    Converts an integer to a string. These are versions of _itoa, _i64toa, _ui64toa, _itow, _i64tow, _ui ...

  5. 【ADO.NET】8、DataSet的使用

    一.DataSet的查询 SqlDataReader 适用于大型数据的读取,它是一条一条的读取,读取出来的数据是存放在服务器上当正在读取数据的时候,突然与服务中断,将无法读取后面的数据DataSet ...

  6. x264_param_t结构

    typedef struct x264_param_t { unsigned int cpu; // CPU 标志位 int i_threads; // 并行编码多帧; 线程数,为0则自动多线程编码 ...

  7. shell中的双引号,单引号,反引号

    在shell中引号分为三种:单引号,双引号和反引号. 单引号 ‘ 由单引号括起来的字符都作为普通字符出现.特殊字符用单引号括起来以后,也会失去原有意义,而只作为普通字符解释.单引号用于保持引号内所有字 ...

  8. PHP类中的__get()和__set函数到底有什么用?

    当试图获取一个不可达变量时,类会自动调用__get. 同样的,当试图设置一个不可达变量时,类会自动调用__set. 在网站中,这两个并不是什么非用不可的函数.   例如: Class Test {   ...

  9. Linux调整SWAP分区

    刪除原swap分區,重建swap,步驟如下:1,swapoff -a #停止交換分區2,fdisk /dev/sda #進入fdisk,刪除原swap分區,重新建立新分區(swap分區的系統ID是82 ...

  10. python入门第一天作业。讲师写的代码。

    #!/uer/bin/env python # _*_ coding: utf-8 _*_ import sys retry_limit = 3 retry_count = 0 account_fil ...