题目:https://www.luogu.org/problemnew/show/P3778

转化有点技巧;

其实直接关注比率的上下两项,也就是盈利和时间;

通过暴枚和 floyd 可以处理出两两点间的最大盈利和最小时间,就不用再去关注原图了;

然后就是裸的01分数规划,枚举 ans ,连完全图,判断正环,若有则答案可行;

注意SPFA里一开始把每个点都入队;还要注意0环,代表此时正好是 ans;

WA了十几遍只因为读入优化少写了一个等号...

细节真令人心碎...50个点,错那么一个两个的...

改成 int ,只把SPFA里的 dis 设成 long long ,就A了...为什么全 long long 就不行啊...

代码如下:

#include<iostream>
#include<cstdio>
#include<cstring>
#include<queue>
using namespace std;
typedef long long ll;
queue<int>q;
int const maxn=,maxk=,inf=0x3f3f3f3f;
int map[maxn][maxn],val[maxn][maxn],l,r,ans,len[maxn],b[maxn][maxk],s[maxn][maxk];
int n,m,K;
ll dis[maxn];
bool vis[maxn];
int rd()
{
int ret=,f=;char ch=getchar();
while(ch<''||ch>'')
{
if(ch=='-')f=-;
ch=getchar();
}
while(ch>=''&&ch<='')ret=ret*+ch-'',ch=getchar();
return ret*f;
}
bool pd(int nw)
{
while(q.size())q.pop();
for(int i=;i<=n;i++)q.push(i),dis[i]=,vis[i]=len[i]=;//每个点入队
while(q.size())
{
int x=q.front(); q.pop(); vis[x]=;
for(int u=;u<=n;u++)
if(dis[u]<=dis[x]+(ll)val[x][u]-(ll)nw*map[x][u])//0环
{
dis[u]=dis[x]+(ll)val[x][u]-(ll)nw*map[x][u];
if(!vis[u])vis[u]=,q.push(u),len[u]++;
// len[u]=len[x]+1;
// if(!vis[u])vis[u]=1,q.push(u);
if(len[u]>n)return ;
}
}
return ;
}
int main()
{
n=rd(); m=rd(); K=rd();
memset(map,0x3f,sizeof map);
// memset(val,-0x3f,sizeof val);
for(int i=;i<=n;i++)
{
// map[i][i]=0;//
for(int j=;j<=K;j++){b[i][j]=rd(); s[i][j]=rd();}
}
for(int i=,x,y,z;i<=m;i++)
{
x=rd(); y=rd(); z=rd();
if(z<map[x][y])map[x][y]=z;
}
for(int k=;k<=n;k++)
for(int i=;i<=n;i++)
for(int j=;j<=n;j++)
// if(map[i][k]!=inf&&map[k][j]!=inf)
map[i][j]=min(map[i][j],map[i][k]+map[k][j]);
for(int i=;i<=n;i++)
for(int j=;j<=n;j++)
// if(map[i][j]!=inf)
{
// val[i][j]=0;//至少是0
for(int k=;k<=K;k++)
if(b[i][k]!=-&&s[j][k]!=-)
// if(b[i][k]>=0&&s[j][k]>=0)
val[i][j]=max(val[i][j],s[j][k]-b[i][k]),r=max(r,val[i][j]);
} l=;r=inf;
while(l<=r)
{
int mid=(l+r)/;
if(pd(mid))ans=mid,l=mid+;
else r=mid-;
}
printf("%d",ans);
return ;
}

洛谷P3778 [APIO2017]商旅——01分数规划的更多相关文章

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

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

  2. 洛谷3778 [APIO2017]商旅

    题目:https://www.luogu.org/problemnew/show/P3778 一看就是0/1分数规划.但不能直接套模板,因为有个商品种类的限制. 考虑从a买在b卖,商品种类根本没用,关 ...

  3. 【bzoj4898】[Apio2017]商旅 Floyd+分数规划+Spfa

    题目描述 有n个点.m条边.和k种商品.第$i$个点可以以$B_{ij}$的价格买入商品$j$,并以$S_{ij}$的价格卖出.任何时候只能持有一个商品.求一个环,使得初始不携带商品时以某种交易方式走 ...

  4. 洛谷 P4377 [USACO18OPEN]Talent Show + 分数规划

    分数规划 分数规划可以用来处理有关分数即比值的有关问题. 而分数规划一般不单独设题,而是用来和dp,图论,网络流等算法结合在一起. 而基础的做法一般是通过二分. 二分题目我们都知道,需要求什么的最小或 ...

  5. 洛谷2494 [SDOI2011]保密 (分数规划+最小割)

    自闭一早上 分数规划竟然还能被卡精度 首先假设我们已经知道了到每个出入口的时间(代价) 那我们应该怎么算最小的和呢? 一个比较巧妙的想法是,由于题目规定的是二分图. 我们不妨通过最小割的形式. 表示这 ...

  6. BZOJ4898/5367 Apio2017商旅(分数规划+floyd)

    如果要在某点买入某物品并在另一点卖出,肯定是走其间最短路径.于是预处理任意两点间的收益和最短路径,连完边二分答案判负环即可,可以全程floyd.注意inf大小. #include<iostrea ...

  7. 【算法】01分数规划 --- HNOI2009最小圈 & APIO2017商旅 & SDOI2017新生舞会

    01分数规划:通常的问法是:在一张有 \(n\) 个点,\(m\) 条边的有向图中,每一条边均有其价值 \(v\) 与其代价 \(w\):求在图中的一个环使得这个环上所有的路径的权值和与代价和的比率最 ...

  8. 洛谷P3199 [HNOI2009]最小圈(01分数规划)

    题意 题目链接 Sol 暴力01分数规划可过 标算应该是这个 #include<bits/stdc++.h> #define Pair pair<int, double> #d ...

  9. 洛谷P2868 [USACO07DEC]观光奶牛Sightseeing Cows(01分数规划)

    题意 题目链接 Sol 复习一下01分数规划 设\(a_i\)为点权,\(b_i\)为边权,我们要最大化\(\sum \frac{a_i}{b_i}\).可以二分一个答案\(k\),我们需要检查\(\ ...

随机推荐

  1. (在线工具)JSON字符串转换成Java实体类(POJO)

    http://www.bejson.com/json2javapojo/ 付代码代码转换示例: public static FixMixedOrderResponse serialization(St ...

  2. hdu2294:Pendant

    T<=10组数据问K<=30种珠子每种n<=1e9串成1~n长度的序列共有多少种,mod1234567891. 方程没想到.矩阵不会推.很好. f[i][j]--长度i,j种珠子方案 ...

  3. JS变量写到HTML页面中并修改变量值(前台处理数据序号问题)

    有时候我们在前台需要对序号进行处理,我们需要将JS变量写到页面中进行显示. 第一种方式:后台处理 第二种方式:JS中定义全局变量,然后进行显示,可以书写一个JS函数对不同的需要进行不同的替换,也就可以 ...

  4. msp430项目编程26

    msp430中项目---串行存储器接口 1.I2C工作原理 2.I2C通信协议 3.代码(显示部分) 4.代码(功能实现) 5.项目总结 msp430项目编程 msp430入门学习

  5. FastDfs + Dht 搭建笔记

    以下为搭建一套分布式文件集群系统,参考了很多资料,自己经过在服务器上搭建并且经过了测试.记录以方便以后使用查看. FastDfs + Dht 安装手册 一:概述 FastDFS是由淘宝的余庆先生所开发 ...

  6. python学习之-- redis模块操作 LIST

    redis 模块操作之 List List 操作,在内存中按照一个name对应一个List来存储. lpush(name,values):在name对应的list中添加元素,每个新的元素都添加到列表的 ...

  7. uva 10559

    记忆话搜索 DP 看了网上题解  状态方程真是巧妙 orz #include <cstdio> #include <cstdlib> #include <cmath> ...

  8. 使用Python实现一个简单的项目监控

    在公司里做的一个接口系统,主要是对接第三方的系统接口,所以,这个系统里会和很多其他公司的项目交互.随之而来一个很蛋疼的问题,这么多公司的接口,不同公司接口的稳定性差别很大,访问量大的时候,有的不怎么行 ...

  9. JSX 语法

    jsx 不能直接运行,是被 babel-loader 中的 react 这个 preset 翻译的 需要注意: 1.必须被一个单独的大标签包裹,比如:div 或者 section 2.标签必须封闭 3 ...

  10. 剑指Offer面试题15(Java版):链表中倒数第K个结点

    题目: 输入一个链表.输出该链表中倒数第k哥结点.  为了符合大多数人的习惯,本题从1開始计数.即链表的尾结点是倒数第1个结点. 比如一个链表有6个结点.从头结点開始它们的值依次是1.2.3,4,5, ...