洛谷P1576||最小花费||dijkstra||双向建边!!
题目描述
在n个人中,某些人的银行账号之间可以互相转账。这些人之间转账的手续费各不相同。给定这些人之间转账时需要从转账金额里扣除百分之几的手续费,请问A最少需要多少钱使得转账后B收到100元。
数据范围
1<=n<=2000,m<=100000
思路分析
可以把每个人看成是一个点,那么题目描述的问题就是使得A->B的花费最少,即两点间的最短路问题,这里我们采用dijkstra算法。
由于m<=100000,故我们采用链式前向星进行存储图,每次找到一个距离原点最近并且没有被访问过的点后,遍历连接此点的每一条边,更新其连接节点的花费
代码(我把dijkstra分为两部分,这样虽然效率低,但是对于我来说思路更清晰些)
#include<iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>
#include<iomanip>
#define N 300010
#define MAXX 1e7+10
#define MINN -1e7+10
using namespace std; struct road
{
int starts,ends,vals;
}ro[N];
double firsts[N],NEXT[N];
int len=;
int n,m,A,B;
double dis[N];
double inputnum[N][];
void insert(int xx,int yy,int zz)
{
len++;
ro[len].starts=xx;ro[len].ends=yy;ro[len].vals=zz;
NEXT[len]=firsts[xx];firsts[xx]=len;
} void init()
{
cin>>n>>m;
for(int i=;i<=m;i++)
{
int aa,bb,cc;
cin>>aa>>bb>>cc;
insert(aa,bb,cc);
insert(bb,aa,cc);
}
cin>>A>>B;
}
bool flag[N];
inline void pre(){ for(int i=;i<=n;i++) dis[i]=MAXX;}
inline void dijkstra1(int st,double vv)//单源点dijkstra
{ for(int i=firsts[st];i;i=NEXT[i]) //如果出度的权值小于当前dis数组的权值,那么就更新dis数组
{
if(dis[st]/(-ro[i].vals*0.01)<dis[ro[i].ends])
{
dis[ro[i].ends]=dis[st]/(-ro[i].vals*0.01);
}
} } void dijkstra()
{
pre();
dis[A]=;
for(int i=firsts[A];i;i=NEXT[i])
{
dis[ro[i].ends]=dis[A]/(-ro[i].vals*0.01);
}
// for(int i=1;i<=n;i++) //cout<<i<<' '<<dis[i]<<' '; //cout<<endl;
for(int j=;j<=n;j++){
double minn=;int temp;
for(int i=;i<=n;i++){
if(i==A) continue;
if(flag[i]==) continue;
if(dis[i]<minn)
{
temp=i;minn=dis[i];
////cout<<dis[i]<<' '<<minn<<endl;
}
}
flag[temp]=;
dijkstra1(temp,minn); }
} void debug_output()
{
for(int i=;i<=len;i++)
cout<<ro[i].starts<<' '<<ro[i].ends<<' '<<ro[i].vals<<' '<<NEXT[i]<<' '<<firsts[ro[i].starts]<<endl; }
int main()
{
// freopen("a.in","r",stdin);
// freopen("a.out","w",stdout);
init();
//debug_output();
dijkstra();
cout<<fixed<<setprecision();
// for(int i=1;i<=n;i++)
cout<<dis[B]<<endl;
return ;
}
洛谷P1576||最小花费||dijkstra||双向建边!!的更多相关文章
- 洛谷—— P1576 最小花费
P1576 最小花费 题目背景 题目描述 在n个人中,某些人的银行账号之间可以互相转账.这些人之间转账的手续费各不相同.给定这些人之间转账时需要从转账金额里扣除百分之几的手续费,请问A最少需要多少钱使 ...
- 洛谷 P1576 最小花费
题目戳 题目描述 在n个人中,某些人的银行账号之间可以互相转账.这些人之间转账的手续费各不相同.给定这些人之间转账时需要从转账金额里扣除百分之几的手续费,请问A最少需要多少钱使得转账后B收到100元. ...
- 洛谷P1576 最小花费x
题目背景 题目描述 在n个人中,某些人的银行账号之间可以互相转账.这些人之间转账的手续费各不相同.给定这些人之间转账时需要从转账金额里扣除百分之几的手续费,请问A最少需要多少钱使得转账后B收到100元 ...
- 浅谈SPFA——洛谷P1576 最小花费 题解
想找原题请点击这里:传送门 原题: 题目描述 在n个人中,某些人的银行账号之间可以互相转账.这些人之间转账的手续费各不相同.给定这些人之间转账时需要从转账金额里扣除百分之几的手续费,请问A最少需要多少 ...
- 洛谷 P1756 最小花费
题目背景 题目描述 在n个人中,某些人的银行账号之间可以互相转账.这些人之间转账的手续费各不相同.给定这些人之间转账时需要从转账金额里扣除百分之几的手续费,请问A最少需要多少钱使得转账后B收到100元 ...
- 1344:【例4-4】最小花费 dijkstra
1344:[例4-4]最小花费 Dijkstra (1)a [ i ] [ j ] 存转账率(..转后所得率..) (2)dis [ i ] 也就是 a [ 起点 ] [ i ] (3)f [ i ] ...
- 洛谷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 题意概括 给出一个有向无环图,现在请你求一些路径,这些路径 ...
随机推荐
- eclipse的常用设置(空间新建后需要的配置)
地址:https://blog.csdn.net/qiaorui_/article/details/78424491 说明: 新下载的eclipse或者新建了一个工作空间,之 ...
- [Unity优化]批处理03:静态批处理
原理: 运行时,把需要进行静态批处理的网格合并到一个新的网格中.虽然只进行一次合并操作,但是会占用更多的内存来存储合并后的网格,并且被静态批处理的物体无法移动旋转缩放 要使用静态批处理,需要把Stat ...
- ORA-12560: TNS:protocol adapter error
C:\Users\dong>sqlplus/nolog SQL*Plus: Release 11.2.0.1.0 Production on Mon Nov 19 14:12:51 2018 C ...
- 佳鑫:信息流广告CTR一样高,哪条文案转化率更好?
在优化信息流广告的过程中,你有没有遇到这样的帐户? 投了几个AB方案,点击率好不容易上去了,但转化率还是有的高.有的低! 这儿就有这么一个为难的案例: 一个广告主计划向有意愿在北京预订酒店的用户投放信 ...
- 关于mysql 表导入数据
一.实验准备: 1.实验设备:Dell laptop 7559; 2.实验环境:windows 10操作系统; 3.数据库版本:mysql 8.0; 二.实验目的: 1.将一个宠物表pet.txt文件 ...
- ERROR 1205 (HY000): Lock wait timeout exceeded; try restarting transaction解决办法
一.问题描述: 同事反馈线上一个表有其中一条数据无法删除,其他都正常,我拿到删数据的sql,尝试执行,报错如下: mysql> delete from facebook_posts where ...
- Java 8 Optional 类
转自:https://www.runoob.com/java/java8-optional-class.html Optional 类是一个可以为null的容器对象.如果值存在则isPresent() ...
- Netty从入门到精通到放弃
有时间想记录一下关于Netty的知识. 第一课:传统IO的特点. package com.example.aimei.controller; import java.io.InputStream; i ...
- 云栖大会day1 下午
下午参与的是创新创业专场 会议议程是 创新创业专场-2018阿里云创新中心年度盛典 13:30-14:10 阿里双创新征程 李中雨 阿里云创业孵化事业部总经理 14:10-14:40 人货场的渗透与重 ...
- 如何在Chrome中导入和导出密码
如果想让 Chrome 支持密码导入和导出,需要先在地址栏中执行 chrome://flags/#password-import-export 将该功能启用并重启浏览器才能生效. 浏览器重启完成后 ...