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 < ...
随机推荐
- ASP SQLDATASOURCE
原文链接:http://blog.csdn.net/dodream/article/details/4887076
- loj #2025. 「JLOI / SHOI2016」方
#2025. 「JLOI / SHOI2016」方 题目描述 上帝说,不要圆,要方,于是便有了这道题. 由于我们应该方,而且最好能够尽量方,所以上帝派我们来找正方形.上帝把我们派到了一个有 NNN ...
- BestCoder Round #80 待填坑
Lucky Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Total Submi ...
- opencv-Haar特征
特征,判决,得到判决 1.什么是haar特征? 特征 = 某个区域的像素点经过某种四则运算之后得到的结果. 这个结果可以是一个具体的值也可以是一个向量,矩阵,多维.实际上就是矩阵运算 2.如何利用特征 ...
- EA添加流程图
- Python-6-字典-函数dict,字典的基本操作及将字符串设置功能用于字典
phonebook = {'Alice': '2341', 'Beth': '9102', 'Cecil': '3258'} 字典由键及其相应的值组成,这种键-值对称为项. 键必须为独一无二,值不必如 ...
- 【Leetcode】Combinations
Given two integers n and k, return all possible combinations of k numbers out of 1 ... n. For exampl ...
- jq ajax超时设置
var ajaxTimeoutTest = $.ajax({ url:'', //请求的URL timeout : 1000, //超时时间设置,单位毫秒 type : 'get', //请求方式,g ...
- 封装OkHttp,通过改造Callback接口实现
1:实现Callback回调接口import android.os.Handler;import android.os.Looper;import android.os.Message; import ...
- python+selenium 使用jinkens构建时,无法打开浏览器(已解决)
inkens 我不用的是war包,就是直接丢在tomcat webapps文件夹就能生效的.因为不是安装,所以网上说把jinkens的服务改为管理员启动是不行的.下面一步步来解决这个问题吧. 1.找到 ...