【BZOJ】2719 银河之星
可以将棋子分为9种类型。且可以通过合并使得两个不同种类棋子转换为另一种棋子(不过要注意棋盘大小,有的时候硬要合并会到棋盘外面,可以先把棋盘全部转换,然后枚举每一个棋子的转换)。然后把状态压成一个十位的十进制数就可以记忆化搜索了。
#include<bits/stdc++.h>
using namespace std;
#define LL long long
#define id(i,j) ((i-1)*3+j-1);
struct point{
int a,b;
}p[];
int k,n,m,x,y,g[][],tot[],change[][];
const int dir[][]={,,,-,,,-,,,,,-,-,,-,-};
LL bg,fin,bin[];
bool flag;
map<LL,int>lis;
bool dfs(LL st){
if(lis[st]){
if(lis[st]==) return true;
return false;
}
if(st==fin) return true;
LL tmp;
for(int i=;i<;i++)
if((st%bin[i+])/bin[i]>){
for(int j=;j<;j++)
if(change[i][j]!=- && (st%bin[j+])/bin[j]>){
tmp=st,tmp=tmp-(bin[i]+bin[j])+bin[change[i][j]];
if(dfs(tmp)) {lis[tmp]=; return true;}
}
}
lis[st]=;
return false;
}
int main(){
bin[]=;
for(int i=;i<=;i++) bin[i]=bin[i-]*;
while(scanf("%d%d%d%d%d",&k,&n,&m,&x,&y)!=EOF){
lis.clear(); bg=; flag=;
int num=id(((x-)%+),((y-)%+));
fin=bin[num];
memset(tot,,sizeof(tot));
memset(change,-,sizeof(change));
for(int a,b,i=;i<=k;i++) {
scanf("%d%d",&a,&b);
p[i]=(point){a,b};
int num=id(((a-)%+),((b-)%+));
tot[num]++;
if(tot[num]==) puts("No"),flag=;
else bg+=bin[num];
}
if(flag) continue;
for(int i=;i<n;i++)
for(int j=;j<m;j++)
g[i+][j+]=id((i%+),(j%+));
for(int i=;i<=n;i++)
for(int j=;j<=m;j++)
for(int d=;d<;d++){
int ta=i+*dir[d][],tb=j+*dir[d][];
if(ta< || ta>n || tb< || tb>m) continue;
change[g[ta-dir[d][]][tb-dir[d][]]][g[i][j]]=change[g[i][j]][g[ta-dir[d][]][tb-dir[d][]]]=g[ta][tb];
}
if(dfs(bg)) puts("Yes");
else puts("No");
}
return ;
}
【BZOJ】2719 银河之星的更多相关文章
- bzoj 1923 [Sdoi2010]外星千足虫(高斯消元+bitset)
		1923: [Sdoi2010]外星千足虫 Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 634 Solved: 397[Submit][Status ... 
- BZOJ 1923: [Sdoi2010]外星千足虫 [高斯消元XOR]
		1923: [Sdoi2010]外星千足虫 对于 100%的数据,满足 N≤1,000,M≤2,000. 裸高斯消元解异或方程组 给定方程顺序要求用从上到下最少的方程,那么找主元时记录一下最远找到哪个 ... 
- BZOJ 1923: [Sdoi2010]外星千足虫
		Description 给出几个异或方程组求解,\(n \leqslant 2000\) Sol 高斯消元. 直接消元就行,遇到自由元就直接输出,同时记录一下用到的最高行数. 复杂度不科学就可以用 b ... 
- bzoj2719[Violet 4]银河之星
		Description Input Output 一道坑爹的搜索……题意是可以往任意方向移动3格,或者如果旁边有格子的时候可以越过它移动,然后把它吃掉.要求吃到最后一个的位置在x0,y0 注意到可以越 ... 
- BZOJ.1923.[SDOI2010]外星千足虫(高斯消元 异或方程组 bitset)
		题目链接 m个方程,n个未知量,求解异或方程组. 复杂度比较高,需要借助bitset压位. 感觉自己以前写的(异或)高斯消元是假的..而且黄学长的写法都不需要回代. //1100kb 324ms #i ... 
- BZOJ 1923 SDOI2010 外星千足虫 异或方程组+bitset
		题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1923 懒得贴题目了......这就是解一个异或方程组的裸题...... YY了一下异或方程 ... 
- bzoj 1923: [Sdoi2010]外星千足虫【高斯消元】
		裸的异或高斯消元 #include<iostream> #include<cstdio> using namespace std; const int N=2005; int ... 
- BZOJ 1923: [Sdoi2010]外星千足虫 高斯消元+bitset
		高斯消元求解异或方程组,可以多学一下 $bitset$ 在位运算中的各种神奇操作. #include <cstdio> #include <bitset> #define N ... 
- bzoj violet系列 (2708~2725)
		cbh大爷说:写博客不能弃坑. orz cbh 那我就来更新博客了. violet这个系列的题好神啊……出题人好劲啊…… ……怎么最近都在理性愉悦啊…… 另外bzoj400题纪念~ 2708: [Vi ... 
随机推荐
- [原创]java WEB学习笔记99:Spring学习---Spring Bean配置:自动装配,配置bean之间的关系(继承/依赖),bean的作用域(singleton,prototype,web环境作用域),使用外部属性文件
			本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱 ... 
- 反射调用方法时的两种情况,走get set和不走get set
			@Test public void test1() throws Exception{ //获取User类 Class class1=Class.forName("cn.jbit.bea ... 
- 为什么要加 -moz- -webkit- -ms- -o- ?
			没有别的,为了兼容早期版本,为了解决CSS3标准正式发布以前的遗留问题. 
- 构建高性能的ASP.NET应用程序
			看见大标题的时候,也许各位看官会自然而然的联想到如何在设计阶段考虑系统性能问题,如何编写高性能的程序代码.关于这一点,大家可以在MSDN和相关网站上找到非常多的介绍,不过大多是防患于未难,提供的是在设 ... 
- [课程设计]Scrum 1.3 多鱼点餐系统开发进度(系统主界面框架&美化)
			Scrum 1.3 多鱼点餐系统开发进度(系统主界面框架&美化) 1.团队名称:重案组 2.团队目标:长期经营,积累客户充分准备,伺机而行 3.团队口号:矢志不渝,追求完美 4.团队选题:餐厅 ... 
- HDU 5690:2016"百度之星" - 初赛 All X
			原文链接:https://www.dreamwings.cn/hdu5690/2657.html All X Time Limit: 2000/1000 MS (Java/Others) Mem ... 
- vs2013-tfs-疑问之版本控制器路径有双引号解决办法
			问题描述: 最近项目:“****”展示交易平台 ,所以版本控制器路径为: 导致生成解决方案提示:路径有问题 解决办法: 1.直接在版本控制器重命名是不支持的,需要安装: Visual Studio ... 
- python(七)字符串格式化、生成器与迭代器
			字符串格式化 Python的字符串格式化有两种方式:百分号方式.format方式 1.百分号的方式 %[(name)][flags][width].[precision]typecode (name) ... 
- hadoop2.0初识1.3
			1.配置分布式hadoop 1.1 准备三台测试机(虚拟机就可以) 1.1.1 将life-hadoop虚拟机克隆2个分别为life-hadoop02和life-hadoop03 1.1.2 查看ip ... 
- Popwindow
			popwindow的使用方法 View contentView = LayoutInflater.from(mContext).inflate( R.layout.dialog_homelist_vi ... 
