当前位置: 首页 > news >正文

【算法】昂贵的聘礼(dijkstra算法)

题目

        年轻的探险家来到了一个印第安部落里。

        在那里他和酋长的女儿相爱了,于是便向酋长去求亲。

        酋长要他用 10000 个金币作为聘礼才答应把女儿嫁给他。

        探险家拿不出这么多金币,便请求酋长降低要求。

        酋长说:”嗯,如果你能够替我弄到大祭司的皮袄,我可以只要 8000 金币。如果你能够弄来他的水晶球,那么只要 5000 金币就行了。”

        探险家就跑到大祭司那里,向他要求皮袄或水晶球,大祭司要他用金币来换,或者替他弄来其他的东西,他可以降低价格。

        探险家于是又跑到其他地方,其他人也提出了类似的要求,或者直接用金币换,或者找到其他东西就可以降低价格。

        不过探险家没必要用多样东西去换一样东西,因为不会得到更低的价格。

        探险家现在很需要你的帮忙,让他用最少的金币娶到自己的心上人。

        另外他要告诉你的是,在这个部落里,等级观念十分森严。

        地位差距超过一定限制的两个人之间不会进行任何形式的直接接触,包括交易。

        他是一个外来人,所以可以不受这些限制。

        但是如果他和某个地位较低的人进行了交易,地位较高的的人不会再和他交易,他们认为这样等于是间接接触,反过来也一样。

        因此你需要在考虑所有的情况以后给他提供一个最好的方案。

        为了方便起见,我们把所有的物品从 1 开始进行编号,酋长的允诺也看作一个物品,并且编号总是 1。

每个物品都有对应的价格 P主人的地位等级 L以及一系列的替代品 Ti 该替代品所对应的”优惠” Vi

如果两人地位等级差距超过了 M,就不能”间接交易”。

你必须根据这些数据来计算出探险家最少需要多少金币才能娶到酋长的女儿。

输入格式

        输入第一行是两个整数 M,N,依次表示地位等级差距限制和物品的总数。

        接下来按照编号从小到大依次给出了 N 个物品的描述。

        每个物品的描述开头是三个非负整数 P、L、X,依次表示该物品的价格、主人的地位等级和替代品总数。

        接下来 X 行每行包括两个整数 T 和 V,分别表示替代品的编号和”优惠价格”。

输出格式

        输出最少需要的金币数。

数据范围

1 ≤ N ≤ 100
1 ≤ P ≤ 10000
1 ≤ L , M ≤ N
0 ≤ X < N

思路

我们可以根据以下样例绘制一张图:

样例:
1 4
10000 3 2
2 8000
3 5000
1000 2 1
4 200
3000 2 1
4 200
50 2 0

        由图可知,我们可以反向建图,从起始点出发到达所有点的距离为物品 i 的原价从点 i 到点 j 的距离为得到物品 i 之后物品 j 的价格。当我们建完图之后,很容易发现这个问题可以抽象成为一个最短路问题。

         对于阶级问题:for(int i = level[ 1 ] - m; i <= level[ 1 ]; i ++) res = min(res,dijkstra(i, i + m));     i 表示可以交换的下界,i + m表示可以交换的上界 ,循环m次即可得到最小的花费。

  

代码

#include<bits/stdc++.h>
using namespace std;
const int N = 110,INF = 0x3f3f3f3f;
int n,m;// n等级差距限制,m物品个数
int w[N][N],level[N];//level数组储存的是第i个物品的主人所处的阶级,w数组储存点i到点j的边权
int dist[N];// 表示当前买到第i件物品价格的最小值
bool st[N];// 表示当前物品的价格是否为最小值int dijkstra(int down,int up)
{memset(dist,0x3f,sizeof(dist));// 将价格初始化为正无穷memset(st,0,sizeof(st));// 所有物品都没有确定最小价格dist[0] = 0;// 将起始点价格初始化为0int i = n;while(i --)// 循环n次确定n个物品的最小价格{int t = -1;// 在没有找到下一个可以确定价格已经最低的物品编号之前,t = -1for(int j = 0; j <= n; j ++)// 本次循环确定价格最小的物品编号if(!st[j] && (t == -1 || dist[t] > dist[j]))t = j;st[t] = true;// 该物品已经确定为最小价格,标记一下for(int j = 1; j <= n; j ++)// 使用这个已经确定最小价格的点对其他点进行更新if(level[j] >= down && level[j] <= up)// 如果阶级不符合条件,则不进行更新dist[j] = min(dist[j],dist[t] + w[t][j]);}return dist[1];
}int main()
{cin >> m >> n;// m等级差距限制,n物品总数memset(w,0x3f,sizeof(w));// 将数组w初始化for(int i = 1;i <= n; i ++) w[i][i] = 0;for(int i = 1;i <= n; i ++){int price,cnt;// price表示物品的价格,cnt表示替代品的数量cin >> price >> level[i] >> cnt;// 依次输入物品的价值,物品主人的阶级,代替品的数量w[0][i] = min(price,w[0][i]);// 起始点到该物品的距离(物品原价)while(cnt --){int id,cost;cin >> id >> cost;// 输入替代品的数量与价格w[id][i] = min(w[id][i],cost);//保留边权最小的值}}int res = INF;// 将答案初始化为正无穷for(int i = level[1] - m; i <= level[1]; i ++) res = min(res,dijkstra(i, i + m));// i表示可以交换的下界,i + m表示可以交换的上界cout << res << endl;return 0;}

相关文章:

  • 力扣日记11.5-【二叉树篇】二叉树的迭代遍历
  • ESP32S3入手体验测试
  • 挑战100天 AI In LeetCode Day01(1)
  • 自动控制原理答案
  • leetcode 684. 冗余连接
  • 故障诊断 | MATLAB实现GRNN广义回归神经网络故障诊断
  • Redis那些事儿(三)
  • Minio多节点多驱动分布式部署官网文档翻译
  • C#将字符串(string)转换为整数(int)几种常见的方法
  • Leetcode—100.相同的树【简单】
  • Linux--线程-条件控制实现线程的同步
  • 在Google Kubernetes集群创建分布式Jenkins(一)
  • vue中app.use()做了什么
  • CSRF攻击(2), 绕过Referer防御
  • 英语——分享篇——每日200词——201-400
  • 【附node操作实例】redis简明入门系列—字符串类型
  • CentOS6 编译安装 redis-3.2.3
  • ES6, React, Redux, Webpack写的一个爬 GitHub 的网页
  • httpie使用详解
  • PAT A1050
  • PHP的Ev教程三(Periodic watcher)
  • React系列之 Redux 架构模式
  • 关于使用markdown的方法(引自CSDN教程)
  • 跨域
  • 利用jquery编写加法运算验证码
  • 算法-插入排序
  • 我是如何设计 Upload 上传组件的
  • 一个项目push到多个远程Git仓库
  • 怎么将电脑中的声音录制成WAV格式
  • 做一名精致的JavaScripter 01:JavaScript简介
  • AI又要和人类“对打”,Deepmind宣布《星战Ⅱ》即将开始 ...
  • ​LeetCode解法汇总2182. 构造限制重复的字符串
  • # linux 中使用 visudo 命令,怎么保存退出?
  • #单片机(TB6600驱动42步进电机)
  • (04)odoo视图操作
  • (CPU/GPU)粒子继承贴图颜色发射
  • (java)关于Thread的挂起和恢复
  • (十二)devops持续集成开发——jenkins的全局工具配置之sonar qube环境安装及配置
  • (图)IntelliTrace Tools 跟踪云端程序
  • (已解决)报错:Could not load the Qt platform plugin “xcb“
  • (原创)Stanford Machine Learning (by Andrew NG) --- (week 9) Anomaly DetectionRecommender Systems...
  • (转)关于pipe()的详细解析
  • .Net 垃圾回收机制原理(二)
  • .NET/C# 编译期间能确定的相同字符串,在运行期间是相同的实例
  • .NET/C# 获取一个正在运行的进程的命令行参数
  • .NET/C# 使用 SpanT 为字符串处理提升性能
  • .NET/C# 在代码中测量代码执行耗时的建议(比较系统性能计数器和系统时间)
  • .net和jar包windows服务部署
  • .net中的Queue和Stack
  • @EnableConfigurationProperties注解使用
  • [ MSF使用实例 ] 利用永恒之蓝(MS17-010)漏洞导致windows靶机蓝屏并获取靶机权限
  • [【JSON2WEB】 13 基于REST2SQL 和 Amis 的 SQL 查询分析器
  • [100天算法】-每个元音包含偶数次的最长子字符串(day 53)
  • [2019.3.20]BZOJ4573 [Zjoi2016]大森林
  • [Android View] 可绘制形状 (Shape Xml)