[dijkstra 图论 最短路] 最小花费

今天给大家讲最小花费这道题目在这里插入图片描述

思路

题目大意就是现在给定一些人之间转账的要给的手续费,让你求出aaa转账给bbb的最小花费。
很显然,为了求出最小花费,又给定了一些人之间要给的手续费。 我们可以吧人看作点,两个人之间可以互相转账看作他们之间有一条路径,要给的手续费为这条路径的权值,那么这个问题就被简化成了一个图论问题。

由于要求最小话费,也就是最短路,所以在这张图中我们又要采用dijkstradijkstradijkstra算法。 但是接下来有几个问题请大家要注意一下。

q1q1q1
由于他给的是手续费,但是在最短路过程中,我们不仅需要手续费,也需要他给了手续费剩下的钱数占总钱数的%几,所以在运算过程中要用100100100%-手续费占总钱的百分比求出剩余钱数的%比
q2q2q2
人之间的手续费是给的百分数,是占总钱数的百分比,所以我们在计算最短路的时候,要把加法改为乘法。
q3q3q3
由于最终计算出来的是给完手续费之后,剩余的钱数,所以我们要用 剩余钱数///最后剩余钱数占花费的百分比,即100/$剩余钱数占花费的百分比 来求出他所需要的最少花费。
q4

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值