可以将棋子分为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 银河之星的更多相关文章

  1. bzoj 1923 [Sdoi2010]外星千足虫(高斯消元+bitset)

    1923: [Sdoi2010]外星千足虫 Time Limit: 10 Sec  Memory Limit: 64 MBSubmit: 634  Solved: 397[Submit][Status ...

  2. BZOJ 1923: [Sdoi2010]外星千足虫 [高斯消元XOR]

    1923: [Sdoi2010]外星千足虫 对于 100%的数据,满足 N≤1,000,M≤2,000. 裸高斯消元解异或方程组 给定方程顺序要求用从上到下最少的方程,那么找主元时记录一下最远找到哪个 ...

  3. BZOJ 1923: [Sdoi2010]外星千足虫

    Description 给出几个异或方程组求解,\(n \leqslant 2000\) Sol 高斯消元. 直接消元就行,遇到自由元就直接输出,同时记录一下用到的最高行数. 复杂度不科学就可以用 b ...

  4. bzoj2719[Violet 4]银河之星

    Description Input Output 一道坑爹的搜索……题意是可以往任意方向移动3格,或者如果旁边有格子的时候可以越过它移动,然后把它吃掉.要求吃到最后一个的位置在x0,y0 注意到可以越 ...

  5. BZOJ.1923.[SDOI2010]外星千足虫(高斯消元 异或方程组 bitset)

    题目链接 m个方程,n个未知量,求解异或方程组. 复杂度比较高,需要借助bitset压位. 感觉自己以前写的(异或)高斯消元是假的..而且黄学长的写法都不需要回代. //1100kb 324ms #i ...

  6. BZOJ 1923 SDOI2010 外星千足虫 异或方程组+bitset

    题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1923 懒得贴题目了......这就是解一个异或方程组的裸题...... YY了一下异或方程 ...

  7. bzoj 1923: [Sdoi2010]外星千足虫【高斯消元】

    裸的异或高斯消元 #include<iostream> #include<cstdio> using namespace std; const int N=2005; int ...

  8. BZOJ 1923: [Sdoi2010]外星千足虫 高斯消元+bitset

    高斯消元求解异或方程组,可以多学一下 $bitset$ 在位运算中的各种神奇操作. #include <cstdio> #include <bitset> #define N ...

  9. bzoj violet系列 (2708~2725)

    cbh大爷说:写博客不能弃坑. orz cbh 那我就来更新博客了. violet这个系列的题好神啊……出题人好劲啊…… ……怎么最近都在理性愉悦啊…… 另外bzoj400题纪念~ 2708: [Vi ...

随机推荐

  1. .NET WebForm简介

    WebForm简介 微软开发的一款产品,它将用户的请求和响应都封装为控件.让开发者认为自己是在操作一个windows界面.极大地提高了开发效率. C/S(客户端) 主要是在本机执行(每一个客户端是独立 ...

  2. C# httprequest post 内容有百分号,部分特殊字符乱码问题

    哎没办法,还没完全脱离.net,已经一半了. http://stackoverflow.com/questions/7908581/how-to-encode-http-post-parameters ...

  3. each(callback) 对于每个匹配的元素所要执行的函数

    以每一个匹配的元素作为上下文来执行一个函数. 意味着,每次执行传递进来的函数时,函数中的this关键字都指向一个不同的DOM元素(每次都是一个不同的匹配元素).而且,在每次执行函数时,都会给函数传递一 ...

  4. Create and Use Custom Attributes

    http://www.codeproject.com/Articles/1811/Creating-and-Using-Attributes-in-your-NET-applicat Create a ...

  5. 如何阅读《ECMAScript 2015 Language Specification》

    你不需要把<ECMAScript 2015 Language Specification>通读一遍,因为没那个必要.   阮一峰建议: 对于一般用户来说,除了第4章,其他章节都涉及某一方面 ...

  6. 从零开始学iPhone开发(1)——工具的使用

    前提:已经具备了苹果电脑或者iMac,或者安装好了x86苹果而且已经联网. 苹果系统版本要求是:Max OS X Lion,或者 Mountain Lion 我们对iPhone进行使用的工具是XCod ...

  7. PHP 回调、匿名函数和闭包

    <?php class Product{ public $name; public $price; function __construct($name, $price){ $this-> ...

  8. 安装DotNetCore.1.0.0-VS2015Tools.Preview2失败解决方案

    1.把安装文件放入非系统盘 2.命令行带参数运行: DotNetCore.1.0.0-VS2015Tools.Preview2.0.1.exe SKIP_VSU_CHECK=1 或 DotNetCor ...

  9. C语言位操作(转)

    http://www.cnblogs.com/cpoint/category/524132.html  

  10. aws在线技术峰会笔记-基于AWS的Devops最佳实践

    AWS CodeCommit AWS CodePipeline 可以和github集成 可以支持蓝绿部署 微服务架构, API Gateway进行转发