bzoj 4898: [Apio2017]商旅【Floyd+分数规划+二分】

其实并不会分数规划
因为要最大化 ans=总收益/总路程 ,所以考虑二分答案,找到一条 ans<=总收益/总路程 的回路。先预处理出d(i,j)为(i,j)最短路,w(i,j)为在i买某个物品在j卖出的最大收益(最小为0)。把式子变一下(据说这是分数规划套路),变成ans*总路程<=总收益,总收益-ans*总路程>=0。建一张新图,(i,j)边权为w(i,j)-d(i,j)*ans,然后用Floyd在新图中检查是否有非负环即可。

#include<iostream>
#include<cstdio>
using namespace std;
const int N=105,K=1005;
const long long inf=1e18;
int n,m,q;
long long b[N][K],s[N][K],d[N][N],a[N][N],c[N][N],w[N][N];
int read()
{int r=0,f=1;char p=getchar();while(p>'9'||p<'0'){if(p=='-')f=-1;p=getchar();}while(p>='0'&&p<='9'){r=r*10+p-48;p=getchar();}return r*f;
}
bool ok(long long mid)
{for(int i=1;i<=n;i++)for(int j=1;j<=n;j++)if(d[i][j]==inf||i==j)a[i][j]=-inf;elsea[i][j]=w[i][j]-mid*d[i][j];for(int k=1;k<=n;k++)for(int i=1;i<=n;i++)for(int j=1;j<=n;j++)a[i][j]=max(a[i][j],a[i][k]+a[k][j]);for(int i=1;i<=n;i++)if(a[i][i]>=0)return 1;for(int i=1;i<=n;i++)for(int j=1;j<=n;j++)c[i][j]=a[i][j];for(int k=1;k<=n;k++)for(int i=1;i<=n;i++)for(int j=1;j<=n;j++)a[i][j]=max(a[i][j],a[i][k]+a[k][j]);for(int i=1;i<=n;i++)for(int j=1;j<=n;j++)if(a[i][j]>c[i][j])return 1;return 0;
}
int main()
{n=read(),m=read(),q=read();for(int i=1;i<=n;i++)for(int j=1;j<=q;j++)b[i][j]=read(),s[i][j]=read();for(int i=1;i<=n;i++)for(int j=1;j<=n;j++)if(i!=j)d[i][j]=inf;for(int i=1;i<=m;i++){int x=read(),y=read(),z=read();d[x][y]=min(d[x][y],(long long)z);}for(int k=1;k<=n;k++)for(int i=1;i<=n;i++)for(int j=1;j<=n;j++)d[i][j]=min(d[i][j],d[i][k]+d[k][j]);for(int i=1;i<=n;i++)for(int j=1;j<=n;j++)for(int k=1;k<=q;k++)if(b[i][k]!=-1&&s[j][k]!=-1)w[i][j]=max(w[i][j],s[j][k]-b[i][k]);long long ans=0,l=0,r=1e12;while(l<=r){long long mid=(l+r)>>1;if(ok(mid))l=mid+1,ans=mid;elser=mid-1;}printf("%lld\n",ans);return 0;
}

转载于:https://www.cnblogs.com/lokiii/p/8793378.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/250567.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

几种链表的优缺点比较

转载于:https://www.cnblogs.com/FengZeng666/p/9425117.html

node --- 模拟express实现一个简单的服务器

目标 使用express实现一个监听3000端口的http服务如下 const express require(express); const app express();app.get(/, (req, res) > {res.end(Hello Express); }) app.get(/users,(req, res)>{res.end(JSON.stringify({name: abc})) }) app.listen(3000, ()>{…

node --- [跨域] 预检请求

简单请求 若满足所有下述条件&#xff0c;则该请求可视为“简单请求”&#xff1a; 使用下列方法之一&#xff1a; GET HEAD POST Content-Type: (仅当POST方法的Content-Type值等于下列之一才算做简单需求) text/plain multipart/form-data application/x-www-form-ur…

Java 的异常

Java 的异常 异常&#xff1a;在Java语言中&#xff0c;将程序执行中发生的不正常情况称为“异常”。(开发过程中的语法错误和逻辑错误不是异常)Java程序在执行过程中所发生的异常事件可分为两类&#xff1a; Error: Java虚拟机无法解决的严重问题。如&#xff1a;JVM系统内部…

docker --- 将已有的项目发布到云端

[运行在win10] Dockerfile Docker根据该文件生成image文件 FROM node:8.4 COPY . /app WORKDIR /app RUN ["npm", "install"] EXPOSE 3000/tcp根据Dockerfile生成image 注意末尾有个.(英文的点)代表当前目录 docker image build -t koa-demo:0.0.1 .查…

传递动态内存

一、内存分配分类 1.从静态存储区域分配。内存在程序编译的时候就已经分配好&#xff0c;这块内存在程序的整个运行期间都存在。例如全局变量&#xff0c;static 变量。 2.在栈上创建。在执行函数时&#xff0c;函数内局部变量的存储单元都可以在栈上创建&#xff0c;函数执行结…

linux --- 基础指令

基础命令 1、ls(list) 用法1: # ls 含义: 列出当前工作目录下所有的 文件/文件夹 的名称 用法2: # ls 路径 含义: 列出指定路径目录下所有的 文件/文件夹 的名称 用法3: # ls 选项 路径 含义: 以指定的格式来显示指定目录下文件夹的名称 栗子: # ls -l 路径 -->> 表…

验证码功能

验证码功能 1.安装captcha插件 (dj_login) D:\dj\dj_login>pip install django-simple-captcha Collecting django-simple-captchaUsing cached https://files.pythonhosted.org/packages/d7/f4/ea95b04ed3abc7bf225716f17e35c5a185f6100db4d7541a 46696ce40351/django-simp…

Java 类的成员

Java 类的成员 初始化块 1、一个类中初始化块若有修饰符&#xff0c;则只能被static修饰&#xff0c;称为静态代码块(staticblock )&#xff0c;当类被载入时&#xff0c;类属性的声明和静态代码块先后顺序被执行&#xff0c;且只被执行一次。 2、static块通常用于初始化sta…

linux --- 进阶指令

进阶指令(重点) 1、df 指令 作用: 查看磁盘空间语法: # df -h 注: -h:以较高可读性的方式展示出来 2、free 指令 作用: 查看内存使用情况语法: # free -m 注: -m:以M的单位显示内存情况 -/ buffers/cache: free 代表真实可用的内存为 486 Mb Swap: 表示,临时将硬盘当作内存…

MFC对话框播放8位512*512的像素数据

关键代码&#xff1a; UINT playAllFrame(LPVOID lpParameter){//showOneFrame(0,TRUE);CMFCDialogDlg *mydlg (CMFCDialogDlg *) lpParameter;//获取原始数据文件CString selectPath;mydlg->GetDlgItemTextW(IDC_MFCEDITBROWSE,selectPath);string StrSelectPath(CW2A(sel…

java 集合 CopyOnWriteArrayList

CopyOnWriteArrayList 也是实现List接口他是在concurrent 包里面&#xff0c;所以他是线程安全的&#xff0c;其他的基本和ArrayList很想。他线程安全是用ReentrantLock 实现的&#xff0c;他内部有一个ReentrantLock对象&#xff0c;然后在增删改的时候都操作这个锁对象&#…

Java 类的特性1

Java 类的特性1 继承 1.为什么要有继承&#xff1f; 多个类中存在相同属性和行为时&#xff0c;将这些内容抽取到单独一个类中&#xff0c;那么多个类无需再定义这些属性和行为&#xff0c;只要继承那个类即可。 2.此处的多个类称为子类&#xff0c;单独的这个类称为父类&a…

linux --- 高级指令

高级指令 1、hostname 指令 作用: 操作(读取|操作)服务器的主机名语法1: # hostname (输出完整的主机名) 语法2: # hostname -f (输出当前主机中的FQDN) FQDN&#xff1a;(Fully Qualified Domain Name)全限定域名&#xff1a;同时带有主机名和域名的名称。 2、id 指令 作…

Linux修改密码后不能SSH远程登录了

1、把以下文件的属性改成755&#xff0c;然后再修改密码&#xff1a;/etc/passwd ,/etc/group , /etc/shadow , /etc/gshadow2、如果文件的属性无法更改&#xff0c;请用lsattr 查看文件是否有 i 属性&#xff0c;如有&#xff0c;则用chattr取消之&#xff0c;如&#xff1a;l…

Java 类的特性2

Java 类的特性2 类属性、类方法的设计思想 类属性作为该类各个对象之间共享的变量。在设计类时,分析哪些类属性不因对象的不同而改变&#xff0c;将这些属性设置为类属性。相应的方法设置为类方法。如果方法与调用者无关&#xff0c;则这样的方法通常被声明为类方法&#xff…

docker --- 镜像、容器

Docker使用国内的源 windows下使用 "everything"软件 查找 daemon.json修改为如下: {"registry_mirrors": ["https://docker.mirrors.ustc.edu.cn"] }查看images(镜像) docker images注: 看见的镜像是已经下载好的,因此在没有网络的情况下也可…

Java 面向对象

Java 面向对象 面向对象的三大特征 封装 (Encapsulation)继承 (Inheritance)多态 (Polymorphism) 类的访问机制&#xff1a; 在一个类中的访问机制&#xff1a;类中的方法可以直接访问类中的成员变量。&#xff08;例外&#xff1a;static方法访问非static&#xff0c;编译…

交换机老化测试和性能测试方法收集

说明&#xff1a;这是一个做交换机朋友给的一个方法&#xff0c;只做老化测试&#xff0c;不做压力满载测试。 我所理解的&#xff1a;老化测试是指在一定的时间内工作负荷之后&#xff0c;看有没有故障和不稳定的现象出现。 而对于压力测试&#xff0c;需要通过专业的测试设备…

【webGL入门2】点线面的绘制

用js绘制webGL的点&#xff1a; THREE.Vector3 function ( x, y, z ) {    //用THREE声明的变量都是全局变量。this.x x || 0;this.y y || 0;this.z z || 0;}; 注意&#xff1a;“||”&#xff08;或&#xff09;运算符&#xff0c;就是当xnull或者undefine时&#xff…