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 ...
随机推荐
- 白昼夢 / Daydream(模拟)
C - 白昼夢 / Daydream Time limit : 2sec / Memory limit : 256MB Score : 300 points Problem Statement You ...
- Cow Contest(传递闭包)
Cow Contest Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 10450 Accepted: 5841 Desc ...
- docker centos yum 源
aliyun yum-config-manager --add-repo https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.rep ...
- Google的Guava之IO升华
版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/luo201227/article/details/36413279 程序员在开发过程中,使用文件的几 ...
- codeforces Gravity Flip 题解
版权声明:本文作者靖心,靖空间地址:http://blog.csdn.net/kenden23/,未经本作者同意不得转载. https://blog.csdn.net/kenden23/article ...
- Swift学习笔记十一:方法
方法是与某些特定类型相关联的功能/函数.在Swift中,结构体和枚举能够定义方法:其实这是Swift与C/Objective-C的主要差别之中的一个. 在Objective-C中,类是唯一能 ...
- Java找出一组数字的最大值
形如:int [] nums = {7,2,8,9,1,12}; 解一:两两比较并记录下标,下次比较拿上次比较的最大值和上次比较的下一个进行比较,循环一次找出最大值 /** * @author 马向峰 ...
- 前端基础-CSS属性操作
前端基础-CSS属性操作 css text 文本颜色:color 颜色属性被用来设置文字的颜色. 颜色是通过CSS最经常的指定: 十六进制值 - 如: #FF0000 一个RGB值 - 如: RGB( ...
- <Linux内核源码>文件系统VFS内核4.0.4版本基本概念源码
题外话:Linux内核从2.x和3.x到现在最新的4.x变化非常大,最直观的表现就是很多书上的内核代码已经无法直接继续使用,所以看看新的源码是非常有意义的! (下文中的内核源码都来自于 kernel ...
- MyBatis入门级Demo
1.创建Java工程MyBatisTest001,导入jar包(mybatis-3.2.1/mysql-connector-java-5.1.24-bin); 2.创建User表,数据库(MySql) ...