瓦西亚和皮台亚摆放了m个方块。方块被编号为0到m-1(每个号码出现恰好一次)。现在建立一个座标系OX表示地面,OY的方向是竖直向上的。每一方块的左下角有一个座标而且是整点座标。
摆放好的方块一定要是稳定的。稳定的含意是每一个不在地面上的方块在他的下面至少有一个方块与他相接触。可以是共边,也可以是共点的。也就是说如果方块座标为(x,y),要么y=0,或者存在一个方块的座标为(x-1,y-1)或者 (x,y-1) 或者 (x+1,y-1)。
现在瓦西亚和皮台亚要轮流把这些方块一个个拆下来。按照拆下来的顺序从左到右摆成一行,那么方块上面的编号就会组成一个m进制的数字。
拆的过程中,要始终保持剩下的方块稳定。瓦西亚想要最终的数字尽可能大,而皮台亚想要尽可能小,瓦西亚先开始拆。
请帮助计算一下最终形成的数字是多少,结果比较大,输出对 109+9 取余后的结果。

解题报告:
用时:1h10min,1WA1TLE
一开始认为就是开优先队列跑拓扑排序,后来发现度不为0也可以入队,所以只拿了60,然后我想到了正确贪心:
对于瓦西亚的从后往前枚举,直到出现第一个能消除的,皮台亚的同理.
然后打了这个贪心的暴力验证一下,发现是对的,考虑优化:
我们把所有可以消除的点丢入优先队列中,然后每次取出编号最小的,我们需要维护一个\(res[i]\),表示\(i\)最下面还有几个没有消除的点,然后我们检查一个点不合法我们就判断其上面的点是否\(res[i]<=1\),注意每消除一个点就要去更新上面点的\(res\)值,并且如果\(res[i]<=1\)时还要check他上方的点的下方的三个点是否会不合法,这样一个点最多入队三次,均摊复杂度\(O(nlogn)\)

#include <algorithm>
#include <iostream>
#include <cstdlib>
#include <cstring>
#include <queue>
#include <cstdio>
#include <vector>
#include <cmath>
#define RG register
#define il inline
#define iter iterator
#define Max(a,b) ((a)>(b)?(a):(b))
#define Min(a,b) ((a)<(b)?(a):(b))
using namespace std;
typedef long long ll;
const int N=1e5+5,inf=1e9+5,mod=1e9+9;
int n;bool vis[N];
struct node{int x,y,id;bool operator <(const node &pp)const{if(y!=pp.y)return y<pp.y;return x<pp.x;}
}a[N];
struct comp{bool operator ()(int &i,int &j)const{return i>j;}
};
priority_queue<int>q;
priority_queue<int,vector<int>,comp>qm;
vector<int>s[N];
int b[N],m=0,num=0,head[N],to[N*3],nxt[N*3],du[N],re[N];
void link(int x,int y){nxt[++num]=head[x];to[num]=y;head[x]=num;}
bool check(int x){if(vis[x])return false;for(int i=head[x];i;i=nxt[i]){if(!vis[to[i]] && du[to[i]]<=1)return false;}return true;
}
bool ca[N];
void solve(){bool t=0;int x;for(int i=1;i<=n;i++){if(!t){while(!q.empty()){if(!ca[q.top()])q.pop();else break;}x=q.top();q.pop();}else{while(!qm.empty()){if(!ca[qm.top()])qm.pop();else break;}x=qm.top();qm.pop();}vis[x]=true;ca[x]=false;for(int k=0,sz=s[x].size(),u;k<sz;k++){u=s[x][k];if(check(u))ca[u]=true,qm.push(u);q.push(u);}for(int j=head[x];j;j=nxt[j]){du[to[j]]--;for(int k=0,sz=s[to[j]].size(),u;k<sz;k++){u=s[to[j]][k];if(!check(u))ca[u]=false;else{ca[u]=true;qm.push(u);q.push(u);}}}re[i]=x-1;t^=1;}ll ans=0,mul=1;for(int i=n;i>=1;i--){ans+=mul*re[i];ans%=mod;mul*=n;mul%=mod;}printf("%lld\n",ans);
}
void work()
{scanf("%d",&n);for(int i=1;i<=n;i++){scanf("%d%d",&a[i].x,&a[i].y);a[i].id=i;}sort(a+1,a+n+1);for(int i=1;i<=n;i++)b[++m]=a[i].y;int sta;for(int i=1;i<=n;i++){sta=lower_bound(b+1,b+m+1,a[i].y-1)-b;for(int j=sta;j<i;j++){if(a[j].y!=a[i].y-1)break;if(abs(a[j].x-a[i].x)<=1){link(a[j].id,a[i].id);du[a[i].id]++;s[a[i].id].push_back(a[j].id);}}}for(int i=1;i<=n;i++){if(check(i))q.push(i),qm.push(i),ca[i]=true;}solve();
}int main()
{work();return 0;
}

转载于:https://www.cnblogs.com/Yuzao/p/7524081.html

51Nod 1530 稳定方块相关推荐

  1. 《软件架构设计》一书目录

    第一部分  软件架构概念与思想篇 1 第1章  解析软件架构概念 3 1.1  软件架构概念的分类 3 1.1.1  组成派 4 1.1.2  决策派 5 1.2  软件架构概念大观 5 1.2.1  ...

  2. 【翻译】在Flash中使用对象池技术稳定内存使用(上)

    [原文链接] http://active.tutsplus.com/tutorials/actionscript/keep-your-flash-projects-memory-usage-stabl ...

  3. 继承WebMvcConfigurer 和 WebMvcConfigurerAdapter类依然CORS报错? springboot 两种方式稳定解决跨域问题

    继承WebMvcConfigurer 和 WebMvcConfigurerAdapter类依然CORS报错???springboot 两种方式稳定解决跨域问题! 之前我写了一篇文章,来解决CORS报错 ...

  4. GStreamer 1.18.4稳定的错误修复版本

    GStreamer 1.18.4稳定的错误修复版本 GStreamer团队宣布最喜欢的跨平台多媒体框架的稳定的1.18版本系列中的另一个错误修复版本! 此版本仅包含错误修复和重要的安全修复程序,并且从 ...

  5. 51nod 1617 奇偶数组

    传送门 回来看一眼51nod,发现自己掉到rank4了,赶紧切道题回rank3. 一眼不会做,这种东西应该慢慢找规律吧--然后看到数据范围其实比较小,应该是单次log的,那是不是可以分治啊. #inc ...

  6. 【BZOJ2140】稳定婚姻 Tarjan

    [BZOJ2140]稳定婚姻 Description 我国的离婚率连续7年上升,今年的头两季,平均每天有近5000对夫妇离婚,大城市的离婚率上升最快,有研究婚姻问题的专家认为,是与简化离婚手续有关. ...

  7. Qt下一行代码就可以使用的稳定易用的日志log类

    Qt下一行代码就可以使用的稳定易用的日志类 此日志类是基于Qt 自带的 扩展的一个易用的日志类, 使用的是Qt自带的日志输出形式, 已长期运行在许多实际项目中,稳定可靠,而且跨平台, 在windows ...

  8. java显示位图_java – 大图标位图在通知中显示为白色方块?

    我有这个问题,我从我在通知中使用的URL生成位图.然而,在我的手机上,Bitmap显示为一个小白色的方块.我看着它,发现很多帖子像这样说: Icon not displaying in notific ...

  9. 电力系统稳定与控制_基于数据驱动的电力系统稳定性分析

    上期内容:世界电网大停电的经验和稳定控制的发展 高薪诚聘电气工程教师.博士后 近期学术会议公告,欢迎参会 详情请按下方导引查阅,戳!戳!戳! 特别致谢报告专家 徐  岩   助理教授 专家介绍 Dr ...

最新文章

  1. Nilearn教程系列(4)-脑部地图集绘制
  2. 介绍了Oracle数据库锁的种类及研究
  3. csdn怎么快速转载别人的文章
  4. ArcGIS Server for JavaScript 3.3 的安装部署
  5. tar.bz2解压异常
  6. python3 下载文件-使用Python 3从网上下载文件
  7. 转: 借助GitHub托管你的项目代码
  8. cCupcake---ToFu
  9. Java拦截器实现拦截controller方法
  10. 惊帆健康监测模块,心率检测模块
  11. 雅虎被收购后,Tumblr 前途未卜,准备在所有博客中引入广告
  12. 记录vue中使用了transition后使用fixed引起的Bug
  13. SAP会计借贷(转载)
  14. 街道字符识别_题目理解(datawhale)
  15. 我给新加坡华人送外卖,一趟5000块
  16. 计算机无法识别u盘,详解电脑不识别u盘
  17. 计算机系统的层次结构 1,1.1 计算机系统的层次结构
  18. 在ubuntu 18上进行NPB和mpiP的整合
  19. 魔都上海财务自由需要多少万?
  20. 图像质量评价方法PSNR+SSIM评估指标SROCC,PLCC

热门文章

  1. 关于禁止svn客户端长驻内存的方法
  2. linux lnmp15 部署laravel项目
  3. alpine_glibc 构建sun jdk 8的docker镜像
  4. 黑客攻防专题八:21种RING的提权方法
  5. 基于Redis、Storm的实时数据查询实践
  6. 庆祝教师节,李宁老师课程优惠劵疯抢中、会员卡优惠中,先到先得
  7. win7中输入文件夹首字母跳到相应的文件或者文件夹,却在搜索栏出现输入的字母...
  8. Simulated Annealing(模拟退火算法)
  9. 股票自动交易使用协议
  10. [转]过度情绪化心智模式的10大特征——看看你有几个?