P1576 最小花费
题目背景
题目描述
在n个人中,某些人的银行账号之间可以互相转账。这些人之间转账的手续费各不相同。给定这些人之间转账时需要从转账金额里扣除百分之几的手续费,请问A最少需要多少钱使得转账后B收到100元。
输入输出格式
输入格式:
第一行输入两个正整数n,m,分别表示总人数和可以互相转账的人的对数。
以下m行每行输入三个正整数x,y,z,表示标号为x的人和标号为y的人之间互相转账需要扣除z%的手续费 (z<100)。
最后一行输入两个正整数A,B。数据保证A与B之间可以直接或间接地转账。
输出格式:
输出A使得B到账100元最少需要的总费用。精确到小数点后8位。
输入输出样例
3 3
1 2 1
2 3 2
1 3 3
1 3
103.07153164
说明
1<=n<=2000
思路:一开始乖乖的打了个Dijkstra记录路径然后慢慢求最后才发现好扯淡也就能过个样例
正确做法是求出每个边的权重然后直接暴力
注意因为有除法的存在所以大于号小于号可能和平常的Dijkstra相反
0分代码
#include<iostream>
#include<cstring>
#include<cstdio>
using namespace std;
int map[][];
double money=;
int dis[];
int maxn=0x7fffff;
int pass[];
int vis[];
int n,m;
int ans[];
void print(int bg,int ed)
{ int now=;
ans[now]=ed;
now++;
int tmp=pass[bg];
while(tmp!=ed&&tmp!=)
{
ans[now]=tmp;
now++;
tmp=pass[tmp];
}
ans[now]=bg;
int qq=ed;
for(int i=;i<=now;i++)
{
money=money/((double)(-map[ans[i-]][ans[i]])/);
}
printf("%.8lf",money);
}
void Dijkstra(int p)
{
memset(dis,0x7f,sizeof(dis));
vis[p]=;
for(int i=;i<=n;i++)
{
dis[i]=map[p][i];
}
for(int i=;i<=n;i++)
{
int minn=maxn;
int k;
for(int j=;j<=n;j++)
{
if(vis[j]==&&dis[j]<minn)
{
minn=dis[j];
k=j;
}
}
vis[k]=;
for(int j=;j<=n;j++)
{
if(dis[j]>dis[k]+map[k][j])
{
dis[j]=dis[k]+map[k][j];
pass[j]=k;
}
}
}
}
int main()
{
memset(map,0x7f,sizeof(map));
scanf("%d%d",&n,&m);
for(int i=;i<=n;i++)
{
int x,y,z;
scanf("%d%d%d",&x,&y,&z);
map[x][y]=z;
map[y][x]=z;
}
int a,b;
scanf("%d%d",&a,&b);
Dijkstra(b);
print(b,a);
return ;
}
AC代码
#include<iostream>
#define MAXN 2001
#define inf 99999
using namespace std;
int N,M,A,B;
double m[MAXN][MAXN];
int main()
{
int i,j;
cin>>N>>M;
cout.setf(ios::fixed);
for (i=;i<N;i++)
for (j=;j<N;j++)
m[i][j]=/inf;
for (i=;i<M;i++)
{
int x,y,t;
cin>>x>>y>>t;
x--; y--;
m[x][y]=m[y][x]=-(t/100.0); //exchange to weight
}
cin>>A>>B;
A--; B--;
//dijkstra
double dis[MAXN]; //dis i:money needed to trans 100 to i
bool book[MAXN];
book[B]=true;
for (i=;i<N;i++)
{
dis[i]=/m[B][i]; //init dis[]
book[i]=false; //init book[]
}
for (j=;j<N;j++)
{
int nmin;
double min=inf;
for (i=;i<N;i++)
if (dis[i]<min&&!book[i])
{
nmin=i;
min=dis[nmin]; //find #min->nmin
}
book[nmin]=true; //record in book[]
for (i=;i<N;i++)
if (min/m[nmin][i]<dis[i]&&!book[i]) //relax
dis[i]=min/m[nmin][i];
}
cout.precision();
cout<<dis[A];
return ;
}
P1576 最小花费的更多相关文章
- 洛谷—— P1576 最小花费
P1576 最小花费 题目背景 题目描述 在n个人中,某些人的银行账号之间可以互相转账.这些人之间转账的手续费各不相同.给定这些人之间转账时需要从转账金额里扣除百分之几的手续费,请问A最少需要多少钱使 ...
- Luogu P1576 最小花费
题目背景 题目描述 在n个人中,某些人的银行账号之间可以互相转账.这些人之间转账的手续费各不相同.给定这些人之间转账时需要从转账金额里扣除百分之几的手续费,请问A最少需要多少钱使得转账后B收到100元 ...
- 洛谷P1576||最小花费||dijkstra||双向建边!!
题目描述 在n个人中,某些人的银行账号之间可以互相转账.这些人之间转账的手续费各不相同.给定这些人之间转账时需要从转账金额里扣除百分之几的手续费,请问A最少需要多少钱使得转账后B收到100元. 数据范 ...
- 洛谷 P1576 最小花费
题目戳 题目描述 在n个人中,某些人的银行账号之间可以互相转账.这些人之间转账的手续费各不相同.给定这些人之间转账时需要从转账金额里扣除百分之几的手续费,请问A最少需要多少钱使得转账后B收到100元. ...
- 洛谷P1576 最小花费x
题目背景 题目描述 在n个人中,某些人的银行账号之间可以互相转账.这些人之间转账的手续费各不相同.给定这些人之间转账时需要从转账金额里扣除百分之几的手续费,请问A最少需要多少钱使得转账后B收到100元 ...
- P1576 最小花费 洛谷
https://www.luogu.org/problem/show?pid=1576 题目背景 题目描述 在n个人中,某些人的银行账号之间可以互相转账.这些人之间转账的手续费各不相同.给定这些人之间 ...
- 浅谈SPFA——洛谷P1576 最小花费 题解
想找原题请点击这里:传送门 原题: 题目描述 在n个人中,某些人的银行账号之间可以互相转账.这些人之间转账的手续费各不相同.给定这些人之间转账时需要从转账金额里扣除百分之几的手续费,请问A最少需要多少 ...
- 把一个序列转换成严格递增序列的最小花费 CF E - Sonya and Problem Wihtout a Legend
//把一个序列转换成严格递增序列的最小花费 CF E - Sonya and Problem Wihtout a Legend //dp[i][j]:把第i个数转成第j小的数,最小花费 //此题与po ...
- 把一个序列转换成非严格递增序列的最小花费 POJ 3666
//把一个序列转换成非严格递增序列的最小花费 POJ 3666 //dp[i][j]:把第i个数转成第j小的数,最小花费 #include <iostream> #include < ...
随机推荐
- poj1811(pollard_rho模板)
题目链接: http://poj.org/problem?id=1811 题意: 判断一个数 n (2 <= n < 2^54)是否为质数, 是的话输出 "Prime" ...
- HTTP协议和WebSocket协议(一)
转自:https://www.jianshu.com/p/0e5b946880b4# HTTP HTTP的地址格式如下: http_URL = "http:" "//&q ...
- P3272 [SCOI2011]地板(插头DP)
[题面链接] https://www.luogu.org/problemnew/show/P3272 [题目描述] 有一个矩阵,有些点必须放,有些点不能放,用一些L型的图形放满,求方案数 [题解] ( ...
- Vim 编辑器中全选操作
ggVG 解释: gg 让光标移到首行,在vim才有效,vi中无效 V 是进入Visual(可视)模式 G 光标移到最后一行
- 解决浏览器location.href重定向失效问题
在[location.href]赋值语句后,添加页面刷新代码[location.reload(true)],参数为[true]这样就等价于F5刷新页面了. 需要注意的是:不能把[location.re ...
- codeforces-473D Mahmoud and Ehab and another array construction task (素数筛法+贪心)
题目传送门 题目大意:先提供一个数组,让你造一个数组,这个数组的要求是 1 各元素之间都互质 2 字典序大于等于原数组 3 每一个元素都大于2 思路: 1.两个数互质的意思就是没有公因子.所以每 ...
- HDU 1565 方格取数(简单状态压缩DP)
http://acm.hdu.edu.cn/showproblem.php?pid=1565 对于每一个数,取或者不取,用0表示不取,1表示取,那么对于每一行的状态,就可以用一个二进制的数来表示.比如 ...
- A reader
A reader lives a thousand lives before he die... The man who never reads lives only one.
- Hash Join是Oracle CBO时代经常出现的一种连接方式
Hash Join是Oracle CBO时代经常出现的一种连接方式,对海量数据处理时经常出现在执行计划里.本篇的上篇(http://space.itpub.net/17203031/viewspace ...
- Jenkins自动化CI CD流水线之6--构建邮件状态通知
一. 前提 前提: 服务器开启邮箱服务: 二. 基础配置 需要安装一个插件: 插件: Email Extension Plugin 进行配置: 系统管理->系统设置-> 相关配置如下图: ...