题目背景

题目描述

在n个人中,某些人的银行账号之间可以互相转账。这些人之间转账的手续费各不相同。给定这些人之间转账时需要从转账金额里扣除百分之几的手续费,请问A最少需要多少钱使得转账后B收到100元。

输入输出格式

输入格式:

第一行输入两个正整数n,m,分别表示总人数和可以互相转账的人的对数。

以下m行每行输入三个正整数x,y,z,表示标号为x的人和标号为y的人之间互相转账需要扣除z%的手续费 (z<100)。

最后一行输入两个正整数A,B。数据保证A与B之间可以直接或间接地转账。

输出格式:

输出A使得B到账100元最少需要的总费用。精确到小数点后8位。

输入输出样例

输入样例#1:

3 3
1 2 1
2 3 2
1 3 3
1 3
输出样例#1:

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 最小花费的更多相关文章

  1. 洛谷—— P1576 最小花费

    P1576 最小花费 题目背景 题目描述 在n个人中,某些人的银行账号之间可以互相转账.这些人之间转账的手续费各不相同.给定这些人之间转账时需要从转账金额里扣除百分之几的手续费,请问A最少需要多少钱使 ...

  2. 洛谷P1576||最小花费||dijkstra||双向建边!!

    题目描述 在n个人中,某些人的银行账号之间可以互相转账.这些人之间转账的手续费各不相同.给定这些人之间转账时需要从转账金额里扣除百分之几的手续费,请问A最少需要多少钱使得转账后B收到100元. 数据范 ...

  3. 洛谷 P1576 最小花费

    题目戳 题目描述 在n个人中,某些人的银行账号之间可以互相转账.这些人之间转账的手续费各不相同.给定这些人之间转账时需要从转账金额里扣除百分之几的手续费,请问A最少需要多少钱使得转账后B收到100元. ...

  4. 洛谷P1576 最小花费x

    题目背景 题目描述 在n个人中,某些人的银行账号之间可以互相转账.这些人之间转账的手续费各不相同.给定这些人之间转账时需要从转账金额里扣除百分之几的手续费,请问A最少需要多少钱使得转账后B收到100元 ...

  5. 浅谈SPFA——洛谷P1576 最小花费 题解

    想找原题请点击这里:传送门 原题: 题目描述 在n个人中,某些人的银行账号之间可以互相转账.这些人之间转账的手续费各不相同.给定这些人之间转账时需要从转账金额里扣除百分之几的手续费,请问A最少需要多少 ...

  6. 洛谷4951 地震 bzoj1816扑克牌 洛谷3199最小圈 / 01分数规划

    洛谷4951 地震 #include<iostream> #include<cstdio> #include<algorithm> #define go(i,a,b ...

  7. Bzoj1486/洛谷P3199 最小圈(0/1分数规划+spfa)/(动态规划+结论)

    题面 Bzoj 洛谷 题解(0/1分数规划+spfa) 考虑\(0/1\)分数规划,设当前枚举到的答案为\(ans\) 则我们要使(其中\(\forall b_i=1\)) \[ \frac{\sum ...

  8. 网络流24题 第三题 - CodeVS1904 洛谷2764 最小路径覆盖问题 有向无环图最小路径覆盖 最大流 二分图匹配 匈牙利算法

    欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - CodeVS1904 题目传送门 - 洛谷2764 题意概括 给出一个有向无环图,现在请你求一些路径,这些路径 ...

  9. 洛谷P3381 最小费用最大流模板

    https://www.luogu.org/problem/P3381 题目描述 如题,给出一个网络图,以及其源点和汇点,每条边已知其最大流量和单位流量费用,求出其网络最大流和在最大流情况下的最小费用 ...

随机推荐

  1. 使用ABAP编程实现对微软Office Word文档的操作

    SAP ABAP里提供了一个标准的类CL_DOCX_DOCUMENT,提供了本地以".docx"结尾的微软Office word文档的读和写操作. 本文介绍了ABAP类CL_DOC ...

  2. vue的使用-项目总结

    1,这是一个重前端逻辑,轻交互,数据展示的项目,可读性差,2,组件划分的坑,复用过多的坑,复用过多导致要在js手动判断太多东西,不便于可读3,vuex的坑,数据分为后台请求数据的暂存,前端页面逻辑的状 ...

  3. Java中的线程--线程中的工具

    这主要想写一下Java中的jdk提供的一些线程中的工具, 一.semaphore信号灯 Semaphore可以维护当前访问自身的线程个数,并提供了同步机制,使用Semaphore可以控制同时访问资源的 ...

  4. rhel7.3smb安装配置

    rhel7.3smb安装配置 1.安装 yum -y install samba samba-client cifs-utils 2.配置开机自启动,覆盖原配置文件 systemctl enable ...

  5. golang 实现冒泡排序

    package main import ( "fmt" ) func main(){ a := [...] int{2,5,9,6,8} fmt.Println(a) num := ...

  6. jQuery实现Ajax

    jQuery.ajax([settings]) type:类型,“POST”或“GET”,默认为GET url:发送地址 data:连同请求发送到服务器的数据 dataType:预期服务器返回的数据类 ...

  7. 【css】清楚浏览器端缓存

    /css/common.css?version=1.0.7   在css链接后面加个参数版本号控制,刷新浏览器缓存

  8. Python9-装饰器进阶-day12

    wapers方法 def wahaha(): ''' sljfldsjflds :return: ''' print('娃哈哈') print(wahaha.__name__) #查看字符串格式的函数 ...

  9. 包含min的栈

    #include <iostream> #include <stack> using namespace std; void push(stack<int> &am ...

  10. cs231n课程索引

    课程资源 课程官网 课程视频-youtube 课程视频-字幕版 官方笔记 官方笔记-中文版 课程作业参考答案