昂贵的聘礼

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

由于有N个物品,我们就可以把它们看作是N个点,从其他点到他的优惠关系视做边,又因为最后总是要找到物品1,所以可以看作是从起点0,到将物品1作为终点的最小路劲。然后由于题目是说,这条路劲上不能有两个的等级差超过M,所以我们可以枚举最小等级,将每个点视作最小等级,这样的话就不会掉解。

又由于我们是枚举的最小等级,所以源点0到其他每个点的边的权值就要赋值为那个点的价格,降等级比最小等级要大,或者差距大于M的其他点标记为不合法(也就是不可以走),然后在从合法的路劲中找出最小花费。

 #include<iostream>
#include<stdio.h>
#include<string.h>
#include<map>
#include<vector>
#include<set>
#include<stack>
#include<queue>
#include<algorithm>
#include<stdlib.h>
using namespace std;
#define MAX(a,b) (a > b ? a : b)
#define MIN(a,b) (a < b ? a : b)
#define mem(a) memset(a,0,sizeof(a))
#define MAXN 105
#define INF 1000000007 int Price[MAXN],Edge[MAXN][MAXN],Level[MAXN];
int vis[MAXN], d[MAXN];
int N,M,ans; void init()
{
mem(Price); mem(Level);
for(int i=;i<=N;i++)
{
for(int j=;j<=N;j++)
{
Edge[i][j] = INF;//初始化每条边都是不连通的
}
}
} void read()
{
int i,j,X,T,TP;
for(i=;i<=N;i++)
{
scanf("%d%d%d",&Price[i], &Level[i], &X);
for(j=;j<X;j++)
{
scanf("%d %d", &T, &TP);
Edge[T][i] = TP;//记录边
}
Edge[][i] = Price[i];
}
} int dijkstra()
{
for(int i=;i<=N;i++)d[i] = Price[i];//源点0到每个点的权值赋为这个点的价格
for(int i=;i<=N;i++)
{
int temp = INF,x;
for(int j=;j<=N;j++)if(!vis[j] && d[j]<=temp)temp = d[x = j];
vis[x] = ;
for(int j=;j<=N;j++)if(d[x]+Edge[x][j] < d[j] && !vis[j])d[j] = d[x]+Edge[x][j];//要从合法的物品中选取,加上!vis[j]
}
return d[];//这里找到的最小值是未知起点的最小值
} int main()
{
while(~scanf("%d %d", &M, &N))
{
init();
read();
ans = INF;
for(int i=;i<=N;i++)
{
int minLevel = Level[i];//将目前的点视作等级最高的点
for(int j=;j<=N;j++)
{
if(Level[j] - minLevel > M || minLevel > Level[j])vis[j] = ;//如果有比它还低的点,或者差超过M,视为不合法
else vis[j] = ;
}
int now = dijkstra();
ans = MIN(ans, now);
}
printf("%d\n", ans);
}
return ;
}

最新文章

  1. sql server2008根据经纬度计算两点之间的距离
  2. PHP RSA参数签名
  3. Win10 VC++6 无法启动此程序,因为计算机中丢失mfc42d.dll 需要提升
  4. UVa 489,紫书P79,刽子手游戏
  5. 能源项目xml文件标签释义--DefaultAdvisorAutoProxyCreator
  6. 【文件系统】浅解释FAT32
  7. linux用户权限相关命令
  8. E6全部刷机包
  9. openJDK之如何下载各个版本的openJDK源码
  10. 2018-2019-1 20189201 《LInux内核原理与分析》第七周作业
  11. POJ3461 Oulipo 字符串
  12. GTP+SDI工程播出部分思路整理(3)
  13. MFC修改窗口无标题和标题信息,修改执执行文件图标
  14. jQuery 复选框全选/取消全选/反选
  15. Chrome 字体模糊解决
  16. 从零开始的Python学习Episode 4——列表
  17. JavaScript(二):对象、注释、事件!
  18. [bzoj1009][HNOI2008]GT考试——KMP+矩阵乘法
  19. pta5-9 Huffman Codes (30分)
  20. Oracle 11g数据库安装与卸载的方法图解(windows)

热门文章

  1. java--关键字和保留字
  2. [转]ASP.NET 页生命周期概述
  3. HelloX操作系统网络功能简介及使用和开发指南
  4. 【C#学习笔记】结构体使用
  5. Control File (二)重建CONTROLFILE --- NORESETLOG
  6. IE8按F12不显示开发人员工具窗口
  7. MVC ActionResult -- JavaScriptResult,JsonResult
  8. Log4NET简介
  9. Spring AOP (上)
  10. [Everyday Mathematics]20150124