bzoj 3232: 圈地游戏 01分数规划
题目大意:
题解:
首先我们看到这道题让我们最优化一个分式.
所以我们应该自然而然地想到01分数规划
首先我们考虑如何恰当地计算所有在封闭多边形内部的权值
我们可以首先假定DZY一定沿着逆时针走,然后我们发现:
我们可以对所有向右,向上的边的\(a\)值都设为在这条边的左侧的同行的价值和.
\(b\)值即为经过这条边的花费
剩下的两条边对应着这两条边将价值取反即可.
我们发现把路线上所有边的\(a\)加起来除二即为围住的元素的val和
所以我们就可以直接01分数规划了.
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
typedef long long ll;
inline void read(int &x){
x=0;char ch;bool flag = false;
while(ch=getchar(),ch<'!');if(ch == '-') ch=getchar(),flag = true;
while(x=10*x+ch-'0',ch=getchar(),ch>'!');if(flag) x=-x;
}
const int maxn = 110;
const double eps = 1e-5;
struct Edge{
int to,next;
double dis,a,b;
}G[maxn*maxn<<3];
int head[maxn*maxn<<2],cnt;
void add(int u,int v,double a,double b){
G[++cnt].to = v;
G[cnt].next = head[u];
head[u] = cnt;
G[cnt].a = a;
G[cnt].b = b;
}
bool inq[maxn*maxn<<2];double dis[maxn*maxn<<2];
#define v G[i].to
bool dfs(int u){
inq[u] = true;
for(int i = head[u];i;i=G[i].next){
if(dis[v] > dis[u] + G[i].dis){
dis[v] = dis[u] + G[i].dis;
if(inq[v]) return true;
if(dfs(v)) return true;
}
}inq[u] = false;
return false;
}
#undef v
int nodecnt;
int id[maxn][maxn];
inline bool check(double mid){
memset(inq,0,sizeof inq);memset(dis,0,sizeof dis);
for(int i=1;i<=cnt;++i) G[i].dis = -(G[i].a - mid*G[i].b);
for(int i=1;i<=nodecnt;++i) if(dfs(i)) return true;
return false;
}
int sl[maxn][maxn],sr[maxn][maxn];
int main(){
int n,m;read(n);read(m);
for(int i=1,x;i<=n;++i){
for(int j=1;j<=m;++j){
read(x);
sl[i][j] = sl[i][j-1] + x;
sr[i][j] = sr[i-1][j] + x;
}
}
for(int i=0;i<=n;++i){
for(int j=0;j<=m;++j){
id[i][j] = ++nodecnt;
}
}
for(int i=0,x;i<=n;++i){
for(int j=1;j<=m;++j){
read(x);
add(id[i][j-1],id[i][j],sr[i][j],x);
add(id[i][j],id[i][j-1],-sr[i][j],x);
}
}
for(int i=1,x;i<=n;++i){
for(int j=0;j<=m;++j){
read(x);
add(id[i-1][j],id[i][j],-sl[i][j],x);
add(id[i][j],id[i-1][j],sl[i][j],x);
}
}
double l = .0,r = 1e9;
while(r-l > eps){
double mid = (l+r)/2.0;
if(check(mid)) l = mid;
else r = mid;
}printf("%.3lf\n",(l/2.0));
getchar();getchar();
return 0;
}
bzoj 3232: 圈地游戏 01分数规划的更多相关文章
- bzoj 3232 圈地游戏 —— 01分数规划+最小割建图(最大权闭合子图)
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3232 心烦意乱的时候调这道题真是...越调越气,就这样过了一晚上... 今天再认真看看,找出 ...
- bzoj 3232: 圈地游戏【分数规划+最小割】
数组开小导致TTTTTLE-- 是分数规划,设sm为所有格子价值和,二分出mid之后,用最小割来判断,也就是判断sm-dinic()>=0 这个最小割比较像最大权闭合子图,建图是s像所有点连流量 ...
- bzoj 3232: 圈地游戏
bzoj 3232: 圈地游戏 01分数规划,就是你要最大化\(\frac{\sum A}{\sum B}\),就二分这个值,\(\frac{\sum A}{\sum B} \geq mid\) \( ...
- 【BZOJ3232】圈地游戏(分数规划,网络流)
[BZOJ3232]圈地游戏(分数规划,网络流) 题面 BZOJ 题解 很神仙的一道题. 首先看到最大化的比值很容易想到分数规划.现在考虑分数规划之后怎么计算贡献. 首先每条边的贡献就变成了\(mid ...
- BZOJ 3232: 圈地游戏 分数规划+判负环
3232: 圈地游戏 Time Limit: 20 Sec Memory Limit: 128 MBSubmit: 966 Solved: 466[Submit][Status][Discuss] ...
- bzoj 3232 圈地游戏——0/1分数规划(或网络流)
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3232 当然是0/1分数规划.但加的东西和减的东西不在一起,怎么办? 考虑把它们合在一起.因为 ...
- BZOJ.4819.[SDOI2017]新生舞会(01分数规划 费用流SPFA)
BZOJ 洛谷 裸01分数规划.二分之后就是裸最大费用最大流了. 写的朴素SPFA费用流,洛谷跑的非常快啊,为什么有人还T成那样.. 当然用二分也很慢,用什么什么迭代会很快. [Update] 19. ...
- BZOJ.4753.[JSOI2016]最佳团体(01分数规划 树形背包DP)
题目链接 \(Description\) 每个点有费用si与价值pi,要求选一些带根的连通块,总大小为k,使得 \(\frac{∑pi}{∑si}\) 最大 \(Solution\) 01分数规划,然 ...
- BZOJ 4753 [Jsoi2016]最佳团体 ——01分数规划 树形DP
要求比值最大,当然用分数规划. 二分答案,转化为选取一个最大的联通块使得它们的和大于0 然后我们直接DP. 复杂度$O(n^2\log {n})$ #include <map> #incl ...
随机推荐
- java jdbc连接数据库,Properties 属性设置参数方法
今天在整合为数据库发现在配置中实现的赋值方式,可以用代码实现.特记录下共以后参考: 代码: // 操作数据库 Connection conn; String strData ...
- uiwebview 屏幕自适应 -- 根据 内容适应或者 webview适应
#import <UIKit/UIKit.h> @interface ViewController : UIViewController<UIWebViewDelegate,UISe ...
- C#练习DataReader
SQL代码: create database ThreeDb go USE ThreeDb; GO CREATE TABLE classify --分类表 ( id ,), name ) not nu ...
- python基础4 ----字符编码
python基础---字符编码 一.了解字符编码 1. 文本编辑器存取文件的原理(nodepad++,pycharm,word) 打开编辑器就打开了启动了一个进程,是在内存中的,所以在编辑器编写的内容 ...
- AbstractQueuedSynchronizer(一)
应该将子类定义为非公共内部帮助器类,一般并发包类用内部类Sync sync来继承并实现.为实现依赖于先进先出 (FIFO) 等待队列的阻塞锁和相关同步器(信号量.事件,等等)提供一个框架.此类的设计目 ...
- Yii2 如何实现表单事件之 Ajax 提交
前言 Yii2 现在使用 JS 都必须要注册代码了. 要实现 Ajax 提交,有两种方法.一是直接在 ActiveForm 调用 beforeSubmit 参数,但是个人认为这样没有很好的把 JS 和 ...
- [原创]java WEB学习笔记10:GenericServlet
本博客为原创:综合 尚硅谷(http://www.atguigu.com)的系统教程(深表感谢)和 网络上的现有资源(博客,文档,图书等),资源的出处我会标明 本博客的目的:①总结自己的学习过程,相当 ...
- F5与Ctrl+F5及地址栏输入地址回车
按F5等同于点击页面地址栏的刷新图标. 地址栏输入地址然后回车: 根据缓存内容是否过期决定是否发送请求给服务端 F5: 浏览器无论如何都得发送请求给服务端,包含If-Modified-Since/If ...
- Eclipse输入命令行参数
想要在Eclipse中输入命令行参数,可以在目录中该程序上右键,选择“Run As",选择”Run configurations",如图: 然后输入命令行参数: 点击Apply和R ...
- Linux电源管理(2)-Generic PM基本概念和软件架构【转】
本文转载自:http://www.wowotech.net/pm_subsystem/generic_pm_architecture.html 1. 前言 这里的Generic PM,是蜗蜗自己起的名 ...