1614: 刘备闯三国之三顾茅庐(二)

Time Limit: 1000 MS  Memory Limit: 128 MB
Submit: 15  Solved: 5
[Submit][Status][Web Board]

Description

 

刘备(161年-223年6月10日),字玄德,东汉末年幽州涿郡涿县,西汉中山靖王刘胜的后代。刘备一生极具传奇色彩,早年颠沛流离、备尝艰辛最终却凭借自己的谋略终成一方霸主。那么在那个风云激荡的年代,刘备又是如何从一个卖草鞋的小人物一步一步成为蜀汉的开国皇帝呢?让我们一起拨开历史的迷雾,还原一个真实的刘备。

公元207年冬至,当时驻军新野的刘备在徐庶的建议下,到南阳卧龙岗拜访诸葛亮。这是刘备第二次拜访诸葛亮的故事。三国演义记载的事,由于诸葛亮被朋友邀请不在家中,刘备再次无功而返。然而据我翻阅古籍发现:其实诸葛亮是抛出了如下的问题,想考察刘备本人的谋略、以确定其是否是自己要效忠的那个人:

这是关于战斗的题目。首先我们将战场分割成n*m个区域,诸葛亮每次可以指挥一只军队占领某一行连续的几个格子或者某一列连续的几个格子。诸葛亮会进行q次操作,他想知道每一次操作后,战场被分割成了几个区域?

刘备为人英明神武,但对此类问题也是束手无策,所以这个任务又要交给刘备身边的小跟班——也就是你来解决了。

 
 

Input

第一行包含3个整数n,m,q(1<=n,m<=1000,1<=q<=10000)。

接下来有q行,每一行包括4个整数x1,x2,y1,y2(保证有x1=x2或者y1=y2),表示诸葛亮将派遣军队占领(x1,y1)到(x2,y2)这一行/列的区域。

Output

对于每一次操作,输出当前战场被分割成几个区域。

初始时,战场为1个区域。

Sample Input

4 6 5
2 2 2 6
1 3 4 3
2 5 3 5
4 6 4 6
1 6 4 6

Sample Output

1
3
3
4
3

HINT

样例每一次操作后的战场如下:

Source

[Submit][Status][Web Board]

题目链接:

  http://acm.xmu.edu.cn/JudgeOnline/problem.php?id=1614

题目大意:

  一个N*M的矩形网格,Q个操作,每次操作会输入x1 y1 x2 y2,使(x1,y1)到(x2,y2)的成为障碍(保证x1=x2 或y1=y2,为一行或一列的连续格子)

  问每次操作后网格内的联通块数量(不含障碍)。

题目思路:

  【逆向思维+二维并查集】

  首先将问题反过来做,每次删去一些障碍,求联通块数量。

  先将所有数据读入,之后用二维并查集统计联通块数量。

  接下来每次都可能删除某些障碍,将新的方格看作新的联通块,然后判断是否会让之前的联通块连通,增减答案。

  最后正序输出答案即可。

 /****************************************************

     Author : Coolxxx
Copyright 2017 by Coolxxx. All rights reserved.
BLOG : http://blog.csdn.net/u010568270 ****************************************************/
#include<bits/stdc++.h>
#pragma comment(linker,"/STACK:1024000000,1024000000")
#define abs(a) ((a)>0?(a):(-(a)))
#define lowbit(a) (a&(-a))
#define sqr(a) ((a)*(a))
#define mem(a,b) memset(a,b,sizeof(a))
const double EPS=1e-;
const int J=;
const int MOD=;
const int MAX=0x7f7f7f7f;
const double PI=3.14159265358979323;
const int N=;
const int M=;
using namespace std;
typedef long long LL;
double anss;
LL aans;
int cas,cass;
int n,m,lll,ans;
int num[N][N],sz[N][N];
int fa[N][N][];
int f[M];
int dx[]={-,,,};
int dy[]={,,,-};
struct xxx
{
int x1,y1,x2,y2;
}q[M];
void zhao(int x,int y,int &fx,int &fy)
{
if((fa[x][y][]==x && fa[x][y][]==y) || (!fa[x][y][] && !fa[x][y][]))
{
fx=x,fy=y;
return;
}
zhao(fa[x][y][],fa[x][y][],fx,fy);
fa[x][y][]=fx;
fa[x][y][]=fy;
}
void print()
{
int i,j;
for(i=;i<=n;i++)
{
for(j=;j<=m;j++)
printf("%d ",num[i][j]);
puts("");
}
puts("");
for(i=;i<=n;i++)
{
for(j=;j<=m;j++)
printf("%d,%d ",fa[i][j][],fa[i][j][]);
puts("");
}
puts("");
for(i=;i<=n;i++)
{
for(j=;j<=m;j++)
printf("%d ",sz[i][j]);
puts("");
}
puts("");
}
int main()
{
#ifndef ONLINE_JUDGE
freopen("1.txt","r",stdin);
// freopen("2.txt","w",stdout);
#endif
int i,j,k;
int x,y,z;
// for(scanf("%d",&cass);cass;cass--)
// for(scanf("%d",&cas),cass=1;cass<=cas;cass++)
// while(~scanf("%s",s))
while(~scanf("%d",&n))
{
mem(num,);mem(sz,);mem(fa,);mem(f,);
scanf("%d%d",&m,&cass);
for(i=;i<=cass;i++)
{
scanf("%d%d%d%d",&q[i].x1,&q[i].y1,&q[i].x2,&q[i].y2);
if(q[i].x1==q[i].x2)
{
if(q[i].y1>q[i].y2)swap(q[i].y1,q[i].y2);
for(j=q[i].y1;j<=q[i].y2;j++)
num[q[i].x1][j]++;
}
else
{
if(q[i].x1>q[i].x2)swap(q[i].x1,q[i].x2);
for(j=q[i].x1;j<=q[i].x2;j++)
num[j][q[i].y1]++;
}
}
for(i=;i<=n;i++)
{
for(j=;j<=m;j++)
{
for(k=;k<;k++)
{
x=i+dx[k];
y=j+dy[k];
if(x< || x>n || y< || y>m || num[i][j] || num[x][y])continue;
int fx1,fy1,fx2,fy2;
zhao(i,j,fx1,fy1);
zhao(x,y,fx2,fy2);
if(fx1==fx2 && fy1==fy2)continue;
fa[fx2][fy2][]=fx1;
fa[fx2][fy2][]=fy1;
}
}
}
for(i=;i<=n;i++)
{
for(j=;j<=m;j++)
{
zhao(i,j,fa[i][j][],fa[i][j][]);
if(!sz[fa[i][j][]][fa[i][j][]] && !num[i][j])f[cass+]++;
sz[fa[i][j][]][fa[i][j][]]++;
}
}
for(i=cass;i>;i--)
{
f[i]=f[i+];
if(q[i].x1==q[i].x2)
{
for(j=q[i].y1;j<=q[i].y2;j++)
{
num[q[i].x1][j]--;
if(num[q[i].x1][j]==)
{
f[i]++;
for(k=;k<;k++)
{
x=q[i].x1+dx[k];
y=j+dy[k];
if(x< || x>n || y< || y>m || num[x][y])continue;
int fx1,fy1,fx2,fy2;
zhao(q[i].x1,j,fx1,fy1);
zhao(x,y,fx2,fy2);
if(fx1==fx2 && fy1==fy2)continue;
fa[fx2][fy2][]=fx1;
fa[fx2][fy2][]=fy1;
f[i]--;
}
}
}
}
else
{
for(j=q[i].x1;j<=q[i].x2;j++)
{
num[j][q[i].y1]--;
if(num[j][q[i].y1]==)
{
f[i]++;
for(k=;k<;k++)
{
x=j+dx[k];
y=q[i].y1+dy[k];
if(x< || x>n || y< || y>m || num[x][y])continue;
int fx1,fy1,fx2,fy2;
zhao(j,q[i].y1,fx1,fy1);
zhao(x,y,fx2,fy2);
if(fx1==fx2 && fy1==fy2)continue;
fa[fx2][fy2][]=fx1;
fa[fx2][fy2][]=fy1;
f[i]--;
}
}
}
}
}
for(i=;i<=cass+;i++)
printf("%d\n",f[i]);
//print();
}
return ;
}
/*
// //
*/

XMU 1614 刘备闯三国之三顾茅庐(二) 【逆向思维+二维并查集】的更多相关文章

  1. XMU 1613 刘备闯三国之三顾茅庐(一) 【并查集】

    1613: 刘备闯三国之三顾茅庐(一) Time Limit: 1000 MS  Memory Limit: 128 MBSubmit: 99  Solved: 29[Submit][Status][ ...

  2. XMU 1615 刘备闯三国之三顾茅庐(三) 【欧拉函数+快速幂+欧拉定理】

    1615: 刘备闯三国之三顾茅庐(三) Time Limit: 1000 MS  Memory Limit: 128 MBSubmit: 45  Solved: 8[Submit][Status][W ...

  3. XMU 1617 刘备闯三国之汉中之战 【BFS+染色】

    1617: 刘备闯三国之汉中之战 Time Limit: 1000 MS  Memory Limit: 128 MBSubmit: 6  Solved: 5[Submit][Status][Web B ...

  4. XMU 1612 刘备闯三国之桃园结义 【二分】

    1612: 刘备闯三国之桃园结义 Time Limit: 1000 MS  Memory Limit: 128 MBSubmit: 181  Solved: 12[Submit][Status][We ...

  5. XMU 1611 刘备闯三国之卖草鞋 【贪心】

    1611: 刘备闯三国之卖草鞋 Time Limit: 1000 MS  Memory Limit: 64 MBSubmit: 90  Solved: 48[Submit][Status][Web B ...

  6. CodeForces - 505B Mr. Kitayuta's Colorful Graph 二维并查集

    Mr. Kitayuta's Colorful Graph Mr. Kitayuta has just bought an undirected graph consisting of n verti ...

  7. B. Mr. Kitayuta's Colorful Graph,二维并查集,一个简单变形就可以水过了~~

    B. Mr. Kitayuta's Colorful Graph ->  Link  <- 题目链接在上面,题目比较长,就不贴出来了,不过这是道很好的题,很多方法都可以做,真心邀请去A了这 ...

  8. [分享] IT天空的二十二条军规

    Una 发表于 2014-9-19 20:25:06 https://www.itsk.com/thread-335975-1-1.html IT天空的二十二条军规 第一条.你不是什么都会,也不是什么 ...

  9. Bootstrap <基础二十二>超大屏幕(Jumbotron)

    Bootstrap 支持的另一个特性,超大屏幕(Jumbotron).顾名思义该组件可以增加标题的大小,并为登陆页面内容添加更多的外边距(margin).使用超大屏幕(Jumbotron)的步骤如下: ...

随机推荐

  1. LeetCode(75) Sort Colors

    题目 Given an array with n objects colored red, white or blue, sort them so that objects of the same c ...

  2. Farthest Nodes in a Tree (求树的直径)

    题目链接,密码:hpu Description Given a tree (a connected graph with no cycles), you have to find the farthe ...

  3. Eclipse设置反编译插件

    有些项目我们想看看引入的包的源码的时候,因为打包好的.class文件的内容我们是看不懂的,但是又懒得去找源码文件的时候,就会用到反编译工具. 步骤: 1.安装反编译插件. 2.设置使用的反编译工具. ...

  4. Vue编写轮播组件引入better-scroll插件无法正常循环轮播

    临近过年还是发个博客表示一下自己的存在感,这段时间公司突然说想搞小程序,想到这无比巨大的坑就只能掩面而泣,于是乎这段时间在学习小程序开发.关于标题所说的是有老铁问的,我也跟着网上的代码码了一遍然后发现 ...

  5. luoguT21777

    #include <algorithm> #include <iostream> #include <cstring> #include <cstdio> ...

  6. WCF部署到IIS的一个浅水滩

    俗话说,浅水淹死牛.昨天下午到今天上午,我就被淹死了一次. 最近在做毕业设计,和一个朋友做,做的是一个APP,我做的是服务器端,因为涉及后台数据更新,所以要有一个后台管理系统,然后还要搭建一个服务给A ...

  7. Leetcode 284.顶端迭代器

    顶端迭代器 给定一个迭代器类的接口,接口包含两个方法: next() 和 hasNext().设计并实现一个支持 peek() 操作的顶端迭代器 -- 其本质就是把原本应由 next() 方法返回的元 ...

  8. php引入PHPMailer发送邮件

    昨天做了一个发送邮件的功能,如果直接用mail()函数,需要拥有自己的邮件服务器,所有引入PHPMailer类方便快捷,简单写一下开发步骤: 一.拥有自己的邮箱账号(作为发件人邮箱) 分两种情况: 1 ...

  9. Python 和 Flask实现RESTful services

    使用Flask建立web services超级简单. 当然,也有很多Flask extensions可以帮助建立RESTful services,但是这个例实在太简单了,不需要使用任何扩展. 这个we ...

  10. springcloud了解

    学习springcloud 文章标题:[置顶] 史上最简单的 SpringCloud 教程 | 终章 学习地址:http://blog.csdn.net/forezp/article/details/ ...