洛谷 P1756 最小花费
题目背景
题目描述
在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
AC代码:
N^2都能过,无语。。
#include<iostream>
#include<cstdio>
#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;// 就这样来看是0 for (i=;i<M;i++)
{
int x,y,t;
cin>>x>>y>>t;
x--; y--;
m[x][y]=m[y][x]=-(t/100.0);//转换成剩余百分之多少
} 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];
}
printf("%.8lf",dis[A]);
return ;
}
80分代码存档:
#include<iostream>
#include<cstdio>
#include<cstring>
#include<queue>
#define N 2005
using namespace std;
int n,m,S,E,head[N],ei;
double dis[N];
bool exist[N];
struct node{
int u,v,next;
double w;
}e[N*];
void add_edge(int u,int v,int x){
double w=(double)x;w/=;
e[++ei].u=u;e[ei].v=v;e[ei].w=w;
e[ei].next=head[u];head[u]=ei;
}
queue<int> q;
void SPFA(){
for(int i=;i<=n;i++) dis[i]=99999999.0;
memset(exist,false,sizeof(exist));
exist[S]=true;q.push(S);dis[S]=100.0;
while(!q.empty()){
int p=q.front();q.pop();
exist[p]=false;
for(int i=head[p];i;i=e[i].next){
int v=e[i].v;
if(dis[v]>dis[p]/(e[i].w)){
dis[v]=dis[p]/(e[i].w);
if(!exist[v]){
q.push(v);exist[v]=true;
}
}
}
}
}
int main()
{
scanf("%d%d",&n,&m);
for(int i=,u,v,w;i<=m;i++){
scanf("%d%d%d",&u,&v,&w);
add_edge(v,u,-w);
add_edge(u,v,-w);
}
scanf("%d%d",&E,&S);
SPFA();
printf("%.8lf",dis[E]);
return ;
}
刚开始用100往回乘(1+e[i].w)全错了,后来改成除了。。
思路:建立无向图(刚开始建成有向图了。。),跑最短路。。

#include<iostream>
#include<cstdio>
#include<cstring>
#include<queue>
using namespace std;
int n,m,S,E,head[],ei;
double dis[];
bool exist[];
struct node{
int u,v,next;
double w;
}e[];
void add_edge(int u,int v,int x){
double w=(double)x;w/=100.0;
e[++ei].u=u;e[ei].v=v;e[ei].w=w;
e[ei].next=head[u];head[u]=ei;
}
queue<int> q;
void SPFA(){
for(int i=;i<=n;i++) dis[i]=99999999.0;
memset(exist,false,sizeof(exist));
exist[S]=true;q.push(S);dis[S]=100.0;
while(!q.empty()){
int p=q.front();q.pop();
exist[p]=false;
for(int i=head[p];i;i=e[i].next){
int v=e[i].v;
if(dis[v]>dis[p]*(1.0+e[i].w)){
dis[v]=dis[p]*(1.0+e[i].w);
if(!exist[v]){
q.push(v);exist[v]=true;
}
}
}
}
}
int main()
{
scanf("%d%d",&n,&m);
for(int i=,u,v,w;i<=m;i++){
scanf("%d%d%d",&u,&v,&w);
add_edge(v,u,w);
add_edge(u,v,w);
}
scanf("%d%d",&E,&S);
SPFA();
printf("%.8lf",dis[E]);
return ;
}
这样写不知道为什么结果总是整数部分正确,小数部分全是0,一时没看出哪里错了
洛谷 P1756 最小花费的更多相关文章
- 洛谷—— P1576 最小花费
P1576 最小花费 题目背景 题目描述 在n个人中,某些人的银行账号之间可以互相转账.这些人之间转账的手续费各不相同.给定这些人之间转账时需要从转账金额里扣除百分之几的手续费,请问A最少需要多少钱使 ...
- 洛谷P1576||最小花费||dijkstra||双向建边!!
题目描述 在n个人中,某些人的银行账号之间可以互相转账.这些人之间转账的手续费各不相同.给定这些人之间转账时需要从转账金额里扣除百分之几的手续费,请问A最少需要多少钱使得转账后B收到100元. 数据范 ...
- 洛谷 P1576 最小花费
题目戳 题目描述 在n个人中,某些人的银行账号之间可以互相转账.这些人之间转账的手续费各不相同.给定这些人之间转账时需要从转账金额里扣除百分之几的手续费,请问A最少需要多少钱使得转账后B收到100元. ...
- 洛谷P1576 最小花费x
题目背景 题目描述 在n个人中,某些人的银行账号之间可以互相转账.这些人之间转账的手续费各不相同.给定这些人之间转账时需要从转账金额里扣除百分之几的手续费,请问A最少需要多少钱使得转账后B收到100元 ...
- 浅谈SPFA——洛谷P1576 最小花费 题解
想找原题请点击这里:传送门 原题: 题目描述 在n个人中,某些人的银行账号之间可以互相转账.这些人之间转账的手续费各不相同.给定这些人之间转账时需要从转账金额里扣除百分之几的手续费,请问A最少需要多少 ...
- 洛谷4951 地震 bzoj1816扑克牌 洛谷3199最小圈 / 01分数规划
洛谷4951 地震 #include<iostream> #include<cstdio> #include<algorithm> #define go(i,a,b ...
- Bzoj1486/洛谷P3199 最小圈(0/1分数规划+spfa)/(动态规划+结论)
题面 Bzoj 洛谷 题解(0/1分数规划+spfa) 考虑\(0/1\)分数规划,设当前枚举到的答案为\(ans\) 则我们要使(其中\(\forall b_i=1\)) \[ \frac{\sum ...
- 网络流24题 第三题 - CodeVS1904 洛谷2764 最小路径覆盖问题 有向无环图最小路径覆盖 最大流 二分图匹配 匈牙利算法
欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - CodeVS1904 题目传送门 - 洛谷2764 题意概括 给出一个有向无环图,现在请你求一些路径,这些路径 ...
- 洛谷P3381 最小费用最大流模板
https://www.luogu.org/problem/P3381 题目描述 如题,给出一个网络图,以及其源点和汇点,每条边已知其最大流量和单位流量费用,求出其网络最大流和在最大流情况下的最小费用 ...
随机推荐
- Python学习日志9月17日 一周总结
周一,9月11日 这天写的是过去一周的周总结,我从中找出当天的内容. 这天早晨给电脑折腾装机,早晨基本上没有学习,休息了一个早晨. 下午写的上周总结,完事做mooc爬虫课的作业,<Think P ...
- UVA 10735 Euler Circuit (最大流)
题意:求混合图的欧拉路径. 一句话总结:网络流,最主要在于建图,此题是将出度则是和流量联系在了一起,用最大流来调整边的指向. 分析: 这题的困难之处在于无向边只能用一次,相当于一个方向未定的有向边. ...
- 关键字: on
关键字: on 数据库在通过连接两张或多张表来返回记录时,都会生成一张中间的临时表,然后再将这张临时表返回给用户. 在使用left jion时,on和where条件的区别如下: 1. on条件是在生成 ...
- easyui树节点拖拽排序的存储过程
easyui树的拖拽排序功能 easyui树中有拖拽功能 树结构如下: 一个行政区域对应一个单位,一个单位对应多个部门,每个部门下有相关人员,功能要求: (1)行政区域没有子节点,点击text加载部门 ...
- shell脚本,按行读取文件的几种方法。
第一种方法用while实现按读取文件.[root@localhost wyb]# cat a.txt 第一行 aaaaaa 第二行 bbbbbb 第三行 cccccc 第四行 dddddd 第五行 e ...
- perl学习之:localtime
Perl中localtime()函数以及sprintf (2011-4-25 19:39)localtime函数 localtime函数,根据它所在的上下文,可以用两种完全不同的方法来运行.在标量上下 ...
- php数据查询之基础查询
---恢复内容开始--- 数据查询语言(Data Query Language) 基本查询 语法形式: select [all | distinct ] 字段或者表达式列表 [from子句] [whe ...
- laravel中的gate
public function boot(){ $this->registerPolicies(); Gate::define('update-post',function($user,$pos ...
- laravel中文字模型的增删改查
模型是用ORM 来做, 使用类来表示一个表,每个表都对应一个模型,以供上层使用 创建模型在项目中的位置定位: /app/下面 好了,我们来创建一个模型: php artisan make:model ...
- python计算机基础(一)
什么是编程语言? 跟计算机交流的语言 什么是编程? 编程就是写代码,让计算机能够听懂的语言 为什么要编程? 让计算机为我们做事,取代人 计算机5大组成分别有什么作用? CPU:控制,判断,配作用,内存 ...