建立平面图的对偶图,把最小割转化成最短路问题

Dijkstra算法堆优化

(被输入顺序搞WA了好几次T_T)

 #include <cstdio>
 #include <cstring>
 #include <algorithm>
 #include <queue>

 ;
 const int maxV=maxN*maxN;
 const int inf=0x3f3f3f3f;

 struct Edge
 {
     int to,next;
     int dist;
     void assign(int t,int n,int d)
         { to=t; next=n; dist=d; }
 };

 Edge elist[maxV*];
 int head[maxV];
 int ecnt;
 int N;
 int dest;

 void initEdge()
 {
     memset(head,-,sizeof(head));
     ecnt=;
 }

 inline void addEdge(int from,int to,int dist)
 {
     elist[ecnt].assign(to,head[from],dist);
     head[from]=ecnt++;
 }

 void input()
 {
     scanf("%d",&N);
     dest=N*N+;
     initEdge();
     int w;
     ;j<=N;j++)
         ;i<=N;i++)
         {
             scanf("%d",&w);
             ,i,w);
             else if(j==N) addEdge(N*N+i-N,dest,w);
             else addEdge(N*j+i-N,N*j+i,w);
         }
     ;j<=N;j++)
         ;i<=N;i++)
         {
             scanf("%d",&w);
             -N,dest,w);
             ,N*j,w);
             -N,N*j+i-N,w);
         }
     ;j<=N;j++)
         ;i<=N;i++)
         {
             scanf("%d",&w);
             if(!j || j==N) continue;
             else addEdge(N*j+i,N*j+i-N,w);
         }
     ;j<=N;j++)
         ;i<=N;i++)
         {
             scanf("%d",&w);
             if(!i || i==N) continue;
             -N,w);
         }
 }

 struct Vertex
 {
     int idx;
     int dist;
     Vertex() {}
     Vertex(int i,int d):idx(i),dist(d) {}
     bool operator < (const Vertex& other) const
         { return this->dist > other.dist; }
 };

 int dist[maxV];
 int open[maxV];
 std::priority_queue<Vertex> que;

 int dijkstra()
 {
     memset(dist,0x3f,sizeof(dist));
     memset(open,,sizeof(open));
     dist[]=; open[]=false;
     ;
     while(cur!=dest)
     {
         ;e=elist[e].next)
         {
             int& to=elist[e].to;
             int& len=elist[e].dist;
             if(open[to] && dist[to]>dist[cur]+len)
             {
                 dist[to]=dist[cur]+len;
                 que.push(Vertex(to,dist[to]));
             }
         }
         Vertex vt;
         do { vt=que.top(); que.pop(); }
         while(!open[vt.idx]);
         cur=vt.idx;
         open[cur]=false;
     }
     return dist[dest];
 }

 int main()
 {
     input();
     printf("%d\n",dijkstra());
     ;
 }

Vijos1734 NOI2010 海拔 平面图最小割的更多相关文章

  1. bzoj2007/luoguP2046 海拔(平面图最小割转对偶图最短路)

    bzoj2007/luoguP2046 海拔(平面图最小割转对偶图最短路) 题目描述: bzoj  luogu 题解时间: 首先考虑海拔待定点的$h$都应该是多少 很明显它们都是$0$或$1$,并且所 ...

  2. BZOJ2007/LG2046 「NOI2010」海拔 平面图最小割转对偶图最短路

    问题描述 BZOJ2007 LG2046 题解 发现左上角海拔为 \(0\) ,右上角海拔为 \(1\) . 上坡要付出代价,下坡没有收益,所以有坡度的路越少越好. 所以海拔为 \(1\) 的点,和海 ...

  3. BZOJ 2007 海拔(平面图最小割转对偶图最短路)

    首先注意到,把一个点的海拔定为>1的数是毫无意义的.实际上,可以转化为把这些点的海拔要么定为0,要么定为1. 其次,如果一个点周围的点的海拔没有和它相同的,那么这个点的海拔也是可以优化的,即把这 ...

  4. 洛谷P2046 [NOI2010]海拔(最小割,平面图转对偶图)

    传送门 不明白为什么大佬们一眼就看出这是最小割…… 所以总而言之这就是一个最小割我也不知道为什么 然后边数太多直接跑会炸,所以要把平面图转对偶图,然后跑一个最短路即可 至于建图……请看代码我实在无能为 ...

  5. bzoj 2007: [Noi2010]海拔【最小割+dijskstra】

    上来就跑3e5的最大流--脑子抽了 很容易看出,每个地方的海拔都是0或1因为再高了没有意义,又,上去下来再上去没有意义,所以最后一定是从s连着一片0,剩下连着t一片1,然后有贡献的就是01交接的那些边 ...

  6. B20J_2007_[Noi2010]海拔_平面图最小割转对偶图+堆优化Dij

    B20J_2007_[Noi2010]海拔_平面图最小割转对偶图+堆优化Dij 题意:城市被东西向和南北向的主干道划分为n×n个区域.城市中包括(n+1)×(n+1)个交叉路口和2n×(n+1)条双向 ...

  7. 【BZOJ2007】【NOI2010】海拔(最小割,平面图转对偶图,最短路)

    [BZOJ2007][NOI2010]海拔(最小割,平面图转对偶图,最短路) 题面 BZOJ 洛谷 Description YT市是一个规划良好的城市,城市被东西向和南北向的主干道划分为n×n个区域. ...

  8. [BZOJ 2007] [Noi2010] 海拔 【平面图最小割(对偶图最短路)】

    题目链接:BZOJ - 2007 题目分析 首先,左上角的高度是 0 ,右下角的高度是 1.那么所有点的高度一定要在 0 与 1 之间.然而选取 [0, 1] 的任何一个实数,都可以用整数 0 或 1 ...

  9. Luogu2046 NOI2010 海拔 平面图、最小割、最短路

    传送门 首先一个不知道怎么证的结论:任意点的\(H\)只会是\(0\)或\(1\) 那么可以发现原题的本质就是一个最小割,左上角为\(S\),右下角为\(T\),被割开的两个部分就是\(H=0\)与\ ...

随机推荐

  1. JAVA中IO技术:BIO、NIO、AIO

    1.同步异步.阻塞非阻塞概念        同步和异步是针对应用程序和内核的交互而言的. 阻塞和非阻塞是针对于进程在访问数据的时候,根据IO操作的就绪状态来采取的不同方式,说白了是一种读取或者写入操作 ...

  2. HDOJ/HDU 1250 Hat's Fibonacci(大数~斐波拉契)

    Problem Description A Fibonacci sequence is calculated by adding the previous two members the sequen ...

  3. 三大跨平台网盘--ubuntu one

    背景介绍 Ubuntu One是由Ubuntu背后的公司Canonical所推出的一项网络服务.该服务能够存储你的文件,并允许你在多台电脑上同步,还可以与好友分享这些文件. 准备工作 帐号--ubun ...

  4. php将SQL查询结果赋值给变量

    2012-03-25 12:12 a786013819 | 分类:数据库DB | 浏览1393次 $sql = "select field1 from pre_common_member_p ...

  5. Building Apps with Over 65K Methods(解决APP引用方法总数超过65536)

    本文翻译自http://developer.android.com/intl/zh-cn/tools/building/multidex.html#about.主要介绍当我们Android App中函 ...

  6. lightoj 1021 - Painful Bases 状态压缩

    题目链接:http://lightoj.com/volume_showproblem.php?problem=1021 #include<cstring> #include<cstd ...

  7. linux trap

  8. poj 1287 Networking【最小生成树prime】

    Networking Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 7321   Accepted: 3977 Descri ...

  9. first blog编程之美-----计算1的个数

    根据以下总结写出以下程序,总结来源于网上 感想:得硬着头皮找规律 #include   int count1(int n) {         int i=1;         int count=0 ...

  10. css3图片滤镜

    http://www.zhanxin.info/development/2012-12-19-css-filter.html