洛谷2046 NOI2010海拔
QwQ题目太长 这里就不复制了
这个题...算是个比较经典的平面图最小割变成对偶图的最短路了QwQ
首先考虑最小割应该怎么做。
有一个性质,就是每个点的海拔要么是1,要么是0
QwQ不过这个我不会证明啊
那么既然知道了这个性质,我们对于地图上的每个点,实际上就是划分成两个集合,一个是\(1\),一个是\(0\)
那么直接最小割就行了
// luogu-judger-enable-o2
#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<cmath>
#include<queue>
using namespace std;
inline int read()
{
int x=0,f=1;char ch=getchar();
while (!isdigit(ch)){if (ch=='-') f=-1;ch=getchar();}
while (isdigit(ch)){x=(x<<1)+(x<<3)+ch-'0';ch=getchar();}
return x*f;
}
const int maxn = 110*110;
const int maxm = 1e6+1e2;
const int inf = 1e9;
int point[maxn];
int nxt[maxm],to[maxm],val[maxm];
int cnt=1;
int h[maxn];
queue<int> q;
int n,m;
int s,t;
void addedge(int x,int y,int w)
{
nxt[++cnt]=point[x];
to[cnt]=y;
val[cnt]=w;
point[x]=cnt;
}
void insert(int x,int y,int w)
{
addedge(x,y,w);
addedge(y,x,0);
}
bool bfs(int s)
{
memset(h,-1,sizeof(h));
h[s]=0;
q.push(s);
while (!q.empty())
{
int x = q.front();
q.pop();
for (int i=point[x];i;i=nxt[i])
{
int p = to[i];
if (val[i]>0 && h[p]==-1)
{
h[p]=h[x]+1;
q.push(p);
}
}
}
if (h[t]==-1) return false;
else return true;
}
int dfs(int x,int low)
{
if (x==t || low==0) return low;
int totflow=0;
for (int i=point[x];i;i=nxt[i])
{
int p = to[i];
if (val[i]>0 && h[p]==h[x]+1)
{
int tmp = dfs(p,min(low,val[i]));
low-=tmp;
totflow+=tmp;
val[i]-=tmp;
val[i^1]+=tmp;
if (low==0) return totflow;
}
}
if (low>0) h[x]=-1;
return totflow;
}
int dinic()
{
int ans=0;
while (bfs(s))
{
ans=ans+dfs(s,inf);
}
return ans;
}
int main()
{
n=read();
n++;
s=1;
t=n*n;
for (int i=1;i<=n;i++)
{
//int now =(i-1)*n;
for (int j=1;j<n;j++)
{
int x = read();
//cout<<x<<endl;
insert((i-1)*n+j,(i-1)*n+j+1,x);
//cout<<(i-1)*n+j<<" "<<(i-1)*n+j+1<<endl;
}
}
for (int i=1;i<n;i++)
for (int j=1;j<=n;j++)
{
int x = read();
insert((i-1)*n+j,i*n+j,x);
}
for (int i=1;i<=n;i++)
{
for (int j=1;j<n;j++)
{
int x = read();
insert((i-1)*n+j+1,(i-1)*n+j,x);
}
}
for (int i=1;i<n;i++)
for (int j=1;j<=n;j++)
{
int x = read();
insert(i*n+j,(i-1)*n+j,x);
}
cout<<dinic()<<endl;
return 0;
}
不过这个最小割的复杂度是爆炸的,显然没法通过这个题,那么我们这时候就需要用到一个很关键的性质了
平面图最小割等于对偶图的最短路
那么什么是对偶图呢?
简单来说,就是把原图的每个封闭面,看成一个点,然后原图的每一种割,对应着新图\(s到t\)的一条路径
但是QwQ这里先留跟个坑,就是关于边的方向的问题....这里还不是很理解呢
转化成新图,建好图之后,直接从\(S\)开始跑最短路,\(dis[t]\)就是答案
一般原图的st和新图的st成对角线的关系
#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<cmath>
#define pa pair<long long,long long>
#include<queue>
using namespace std;
inline long long read()
{
long long x=0,f=1;char ch=getchar();
while (!isdigit(ch)){if (ch=='-') f=-1;ch=getchar();}
while (isdigit(ch)){x=(x<<1)+(x<<3)+ch-'0';ch=getchar();}
return x*f;
}
const int maxn = 510;
const int N = maxn*maxn;
const int maxm = 2e6+1e2;
int a[maxn][maxn][maxn];
int point[N],nxt[maxm],to[maxm];
int cnt;
int vis[N];
int n,m;
long long dis[N],val[maxm];
priority_queue<pa,vector<pa>,greater<pa> > q;
int s,t;
void addedge(int x,int y,long long w){
nxt[++cnt]=point[x];
to[cnt]=y;
val[cnt]=w;
point[x]=cnt;
}
void splay(int s)
{
memset(vis,0,sizeof(vis));
memset(dis,127/3,sizeof(dis));
//cout<<dis[1]<<endl;
dis[s]=0;
q.push(make_pair(0,s));
while (!q.empty())
{
//cout<<1<<endl;
int x = q.top().second;
q.pop();
//cout<<x<<endl;
if (vis[x]) continue;
vis[x]=1;
for (int i=point[x];i;i=nxt[i])
{
int p = to[i];
if (dis[p]>dis[x]+val[i])
{
dis[p]=dis[x]+val[i];
//cout<<dis[p]<<" "<<p<<endl;
q.push(make_pair(dis[p],p));
//cout<<endl;
}
}
}
}
inline int getnum(int x,int y)
{
if (x==0 || y==n) return t;
if (x==n || y==0 ) return s;
return (x-1)*(n-1)+y;
}
int main()
{
n=read();
n++;
s=N-6;
t=s+1;
for (int i=1;i<=n;i++)
for (int j=1;j<n;j++)
{
long long x=read();
addedge(getnum(i,j),getnum(i-1,j),x);
//cout<<getnum(i,j)<<" "<<getnum(i-1,j)<<endl;
}
for (int i=1;i<n;i++)
for (int j=1;j<=n;j++)
{
long long x = read();
addedge(getnum(i,j-1),getnum(i,j),x);
//cout<<getnum(i,j-1)<<" "<<getnum(i,j)<<endl;
//cout<<x<<endl;
}
for (int i=1;i<=n;i++)
for (int j=1;j<n;j++)
{
long long x=read();
addedge(getnum(i-1,j),getnum(i,j),x);
}
for (int i=1;i<n;i++)
for (int j=1;j<=n;j++)
{
long long x = read();
addedge(getnum(i,j),getnum(i,j-1),x);
}
splay(s);
cout<<dis[t];
return 0;
}
洛谷2046 NOI2010海拔的更多相关文章
- 洛谷$P2046\ [NOI2010]$海拔 网络流+对偶图
正解:网络流+对偶图 解题报告: 传送门$QwQ$ $umm$之前省选前集训的时候叶佬考过?然而这和我依然不会做有什么关系呢$kk$ 昂这题首先要两个结论?第一个是说每个位置的海拔一定是0/1,还一个 ...
- 洛谷P2046 [NOI2010]海拔(最小割,平面图转对偶图)
传送门 不明白为什么大佬们一眼就看出这是最小割…… 所以总而言之这就是一个最小割我也不知道为什么 然后边数太多直接跑会炸,所以要把平面图转对偶图,然后跑一个最短路即可 至于建图……请看代码我实在无能为 ...
- [洛谷P2048] [NOI2010] 超级钢琴
洛谷题目链接:[NOI2010]超级钢琴 题目描述 小Z是一个小有名气的钢琴家,最近C博士送给了小Z一架超级钢琴,小Z希望能够用这架钢琴创作出世界上最美妙的音乐. 这架超级钢琴可以弹奏出n个音符,编号 ...
- 洛谷P1447 - [NOI2010]能量采集
Portal Description 给出\(n,m(n,m\leq10^5),\)计算\[ \sum_{i=1}^n \sum_{j=1}^m (2gcd(i,j)-1)\] Solution 简单 ...
- 洛谷 P1954 [NOI2010]航空管制
https://www.luogu.org/problemnew/show/P1954 拓扑排序, 注意到如果正着建图("a出现早于b"=>"a向b连边" ...
- 洛谷 P2048 [NOI2010]超级钢琴 解题报告
P2048 [NOI2010]超级钢琴 题目描述 小Z是一个小有名气的钢琴家,最近C博士送给了小Z一架超级钢琴,小Z希望能够用这架钢琴创作出世界上最美妙的音乐. 这架超级钢琴可以弹奏出n个音符,编号为 ...
- 洛谷P0248 [NOI2010] 超级钢琴 [RMQ,贪心]
题目传送门 超级钢琴 题目描述 小Z是一个小有名气的钢琴家,最近C博士送给了小Z一架超级钢琴,小Z希望能够用这架钢琴创作出世界上最美妙的音乐. 这架超级钢琴可以弹奏出n个音符,编号为1至n.第i个音符 ...
- 洛谷P1447 [NOI2010]能量采集(容斥)
传送门 很明显题目要求的东西可以写成$\sum_{i=1}^{n}\sum_{j=1}^m gcd(i,j)*2-1$(一点都不明显) 如果直接枚举肯定爆炸 那么我们设$f[i]$表示存在公因数$i$ ...
- 洛谷 P2048 [NOI2010]超级钢琴(优先队列,RMQ)
传送门 我们定义$(p,l,r)=max\{sum[t]-sum[p-1],p+l-1\leq t\leq p+r-1 \}$ 那么因为对每一个$p$来说$sum[p-1]$是一个定值,所以我们只要在 ...
随机推荐
- 你不知道的echarts,前端鲍哥带你研究!
前言 相信不少前端小伙伴刚接触 e-charts 肯定有点陌生,但是echarts咱不清楚,charts我们应该很熟悉,没错,echarts 就是我们日常可见的图表,不同的是 echarts 是用代码 ...
- ES6——简单的多态
简单的多态 多态: 1.同一个接口,在不同情况下做不一样的事情:相同的接口,不同的表现: 2.接口本身只是一组定义,实现都是子类里面:需要子类去实现的方法(子类只需重写与父类同名的方法,即可达到覆盖的 ...
- Android中TextView和EditView常用属性设置
Android中TextView和EditView常用属性设置 点击跳转
- 【详细、开箱即用】.NET企业微信回调配置(数据回调URL和指令回调URL验证)
前言: 前段时间因为公司业务需求,需要将微信小程序与企业微信对接通,也就是把小程序绑定到对应的企业微信账号下,在该企业微信的用户可以将该小程序绑定到工作台中,然后可以在工作台中打开该小程序并授权.不过 ...
- WinUI 3学习笔记(3)—— ComboBox & DropDownButton & SplitButton
本篇想介绍相对小众但颇具使用价值的控件SplitButton,提到SplitButton难免会拿来与ComboBox进行比较,同时在WinUI 3的控件库中,还有一个默默无闻的DropDownButt ...
- webService动态调用及返回至处理
http://www.cnblogs.com/xffy1028/archive/2012/05/07/2487595.html using System; using System.Collectio ...
- STM32F103C8T6使用SPI接口驱动WS2812b灯条
之前一篇文章写了使用IO控制WS2812b操作原理,但是由于IO的输出比较慢,所以现在改用了硬件SPI控制WS2812b灯条 把SPI的mosi线接到ws2812b的数据线,SPI的速率可达十几Mbi ...
- PHP的Mhash扩展函数的学习
这次我们要学习的又是一个 Hash 加密扩展.不过这个扩展 Mhash 已经集成在了 Hash 扩展中.同时也需要注意的是,这个扩展已经不推荐使用了,我们应该直接使用 Hash 扩展中的函数来进行 H ...
- npm WARN ajv-keywords@2.1.1 requires a peer of ajv@^5.0.0 but none is installed. You must install peer dependencies yourself.
解决: npm install -g npm-install-peers npm install -g npm npm i ajv 但是好像没啥用
- Linux系列(18) - 常用压缩命令(1)
常用压缩格式 .zip .gz .bz2 .zip格式压缩/解压缩 命令格式 压缩 zip [压缩文件名] [源文件]:压缩文件 zip -r [压缩文件名] [源目录]:压缩目录 解压缩 unzip ...