【题目分析】

可以知道,所有的海拔是0或1

最小割转最短路,就可以啦

SPFA被卡,只能换DIJ

【代码】

#include <cstdio>
#include <cstring>

#include <iostream>
#include <algorithm>
#include <queue>

using namespace std;

#define maxn 2000005

int h[maxn],to[maxn],ne[maxn],w[maxn],en=0;

int read()
{
    int x=0,f=1; char ch=getchar();
    while (ch<'0'||ch>'9') {if (ch=='-') f=-1; ch=getchar();}
    while (ch>='0'&&ch<='9') {x=x*10+ch-'0'; ch=getchar();}
    return x*f;
}

int dis[maxn];
struct cmp{
    bool operator () (const int &a,const int &b)
    {return dis[a]>dis[b];}
};

struct Table
{
    int h[maxn],ne[maxn],to[maxn],w[maxn],vis[maxn];
    priority_queue <int,vector <int>,cmp> q;
    int en;
    void init()
    {
        memset(h,-1,sizeof h);
        en=0;
        while (!q.empty()) q.pop();
    }
    void add(int a,int b,int c)
    {
        ne[en]=h[a];
        to[en]=b;
        w[en]=c;
        h[a]=en++;
    }
    void dij(int s)
    {
        memset(dis,0x3f,sizeof dis);
        memset(vis,0,sizeof vis);
        dis[s]=0;
        q.push(s);
        vis[s]=1;
        while (!q.empty())
        {
            int x=q.top(); q.pop(); vis[x]=0;
            for (int i=h[x];i>=0;i=ne[i])
            {
                if (dis[to[i]]>dis[x]+w[i])
                {
                    dis[to[i]]=dis[x]+w[i];
                    if (!vis[to[i]])
                    {
                        vis[to[i]]=1;
                        q.push(to[i]);
                    }
                }
            }
        }
    }
}map;

void add(int a,int b,int c)
{
	to[en]=b;
	ne[en]=h[a];
	w[en]=c;
	h[a]=en++;
}

int n,S=0,T=maxn-1;
int hash[605][605],cnt=0;
int inq[maxn];

void SPFA()
{
	queue <int> q;
	memset(dis,0x3f,sizeof dis);
	while (!q.empty()) q.pop();
	q.push(S); inq[S]=1; dis[S]=0;
	while (!q.empty())
	{
		int x=q.front(); q.pop(); inq[x]=0;
		for (int i=h[x];i>=0;i=ne[i])
		{
			if (dis[to[i]]>dis[x]+w[i])
			{
				dis[to[i]]=dis[x]+w[i];
				if (!inq[to[i]])
				{
					inq[to[i]]=1;
					q.push(to[i]);
				}
			}
		}
	}
	printf("%d\n",dis[T]);
}

int main()
{
	map.init();
	memset(h,-1,sizeof h);
	n=read();
	for (int i=0;i<=n+1;++i)
		for (int j=0;j<=n+1;++j)
			hash[i][j]=++cnt;
	for (int i=0;i<=n+1;++i) hash[0][i]=maxn-1;
	for (int i=0;i<=n+1;++i) hash[n+1][i]=0;
	for (int i=0;i<=n+1;++i) hash[i][0]=0;
	for (int i=0;i<=n+1;++i) hash[i][n+1]=maxn-1;
	for (int i=1;i<=n+1;++i)
		for (int j=1;j<=n;++j)
		{
			int tmp=read();
			map.add(hash[i][j],hash[i-1][j],tmp);
		}
	for (int i=1;i<=n;++i)
		for (int j=1;j<=n+1;++j)
		{
			int tmp=read();
			map.add(hash[i][j-1],hash[i][j],tmp);
		}
	for (int i=1;i<=n+1;++i)
		for (int j=1;j<=n;++j)
		{
			int tmp=read();
			map.add(hash[i-1][j],hash[i][j],tmp);
		}
	for (int i=1;i<=n;++i)
		for (int j=1;j<=n+1;++j)
		{
			int tmp=read();
			map.add(hash[i][j],hash[i][j-1],tmp);
		}
	map.dij(S);
	printf("%d\n",dis[T]);
}

  

NOI 2010 海拔 ——平面图转对偶图的更多相关文章

  1. BZOJ2007 NOI2010 海拔 平面图转对偶图 最小割

    题面太长啦,请诸位自行品尝—>海拔 分析: 这是我见过算法比较明显的最小割题目了,很明显对于某一条简单路径,海拔只会有一次变换. 而且我们要最终使变换海拔的边权值和最小. 我们发现变换海拔相当于 ...

  2. [NOI2010]海拔 平面图转对偶图 最小割

    题解: 首先,我们不难猜到高度只有 $0$ 或 $1$ 两种可能,而且高度为 0 的地区组成一个联通块,高度为 1 的地区组成一个联通块.只有这样,人们所耗费的体力才是最小的.得出这个结论,题目就成了 ...

  3. NOI 2010 海拔(最小割转最短路)

    题意 https://www.lydsy.com/JudgeOnline/problem.php?id=2007 思路 首先可以发现一个结论,每个位置的海拔只有能是 \(0\) 和 \(1\) ,然后 ...

  4. P2046 [NOI2010]海拔 平面图转对偶图(最小割-》最短路)

    $ \color{#0066ff}{ 题目描述 }$ YT市是一个规划良好的城市,城市被东西向和南北向的主干道划分为n×n个区域.简单起见,可以将YT市看作 一个正方形,每一个区域也可看作一个正方形. ...

  5. ●BZOJ 2007 NOI 2010 海拔

    题链: http://www.lydsy.com/JudgeOnline/problem.php?id=2007 题解: 网络流.最小割.对偶图 奇妙的题 ~ 种种原因导致了高度要么为 0,要么为 1 ...

  6. 【BZOJ-2007】海拔 最小割 (平面图转对偶图 + 最短路)

    2007: [Noi2010]海拔 Time Limit: 20 Sec  Memory Limit: 552 MBSubmit: 2095  Solved: 1002[Submit][Status] ...

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

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

  8. 【BZOJ 2007】 2007: [Noi2010]海拔 (平面图转对偶图+spfa)

    2007: [Noi2010]海拔 Time Limit: 20 Sec  Memory Limit: 552 MBSubmit: 2504  Solved: 1195 Description YT市 ...

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

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

随机推荐

  1. <<< web里面Servlet高级应用的基础介绍

    Servlet中的页面跳转?两种方式,实现跳转:内部跳转(请求转发).外部跳转(重定向)内部跳转(请求转发)特点:在服务器内部完成页面之间的跳转:请求只有一次:浏览器地址不会改变.request.ge ...

  2. elastichq auto connect

    $(document).ready(function () { $('#connectionURL').focus(); ajaxloading.hide(); scrollToTop.activat ...

  3. Java学习笔记12

    循环 打印一个字符串(例如: "Welcome to Java!") 100次,就需要吧下面的输出语句重复写100遍,这是相当繁琐的: System.out.println(&qu ...

  4. css3动画简介以及动画库animate.css的使用

    在这个年代,你要是不懂一点点css3的知识,你都不好意思说你是个美工.美你妹啊,请叫我前端工程师好不好.呃..好吧,攻城尸...呵呵,作为一个攻城尸,没有点高端大气上档次的东西怎么能行呢,那么css3 ...

  5. mysql 存储过程在批处理数据中的应用

    最近批处理数据的时候,突然想到:为什么不使用存储过程进行数据批处理? 为什么要进行批处理? 自答:减少数据库连接次数,提高效率. 存储过程批处理数据的优点:一次编译,永久执行. 这次的批处理逻辑较简单 ...

  6. JavaScript 冒泡排序和选择排序

    var array = [1,2,3,4,5]; // ---> 服务 //效率 ---> 针对一个有序的数组 效率最高 //标志 true false for(var j = 0; j ...

  7. PHP流式上传和表单上传(美图秀秀)

    最近需要开发一个头像上传的功能,找了很多都需要授权的,后来找到了美图秀秀,功能非常好用. <?php /** * Note:for octet-stream upload * 这个是流式上传PH ...

  8. 《征服 C 指针》摘录3:数组 与 指针

    一.数组 和 指针 的微妙关系 数组 是指将固定个数.相同类型的变量排列起来的对象. 正如之前说明的那样,给指针加 N,指针前进“当前指针指向的变量类型的长度 X N”. 因此,给指向数组的某个元素的 ...

  9. redis使用简介

    1.redis 支持"生产者与消费者模式"."订阅模式" 2.实时数据, 用数据类型.时间戳.数据内容,以二进制形式存取 3.查询时间.查询间隔时间.查询更新时 ...

  10. Git教程推荐

    推荐:廖雪峰的官方网站-Git教程,面向初学者,浅显易懂.