方格分割

标题:方格分割
 
6x6的方格,沿着格子的边线剪开成两部分。
要求这两部分的形状完全相同。
 
如图:p1.png, p2.png, p3.png 就是可行的分割法。
 这里写图片描述
试计算:
包括这3种分法在内,一共有多少种不同的分割方法。
注意:旋转对称的属于同一种分割法。
 
请提交该整数,不要填写任何多余的内容或说明文字。
  

从中心点开始搜索,每次可以走四个方向。搜索的过程要将中心对称点顺便标记,结果除以4

思路主要就是搜索他的切割线,把他的每种情况的切割线搜出来,虽然方块不是一笔画,但是他的切割线肯定是一个一笔画啊(一刀两快儿

),而且每一种切割线都会经过中间的那个点(肯定啊!!(3,3)和(4,4)肯定不在同一个块儿里面啊~~~所以切割线肯定会经过他们相邻的那个点),切割线应该从中点开始搜索,而且只要搜索到边线(就是已经把方块分成两部分了)就可以结束,从中点开始搜第一步有四个方向,而且任意一个方向反转一下都可以得到另一个方向的所有情况,所以使用边线搜索的结果最后应该除以/4,下面是从网上搜到的代码:出自http://blog.csdn.net/y1196645376/article/details/69718192/

public class 方格分割 {
	      static int ans;
	      static int[][] vis=new int[7][7];
	      static int[][] dis= {{1,0},{0,1},{-1,0},{0,-1}};
          public static void main(String[] args) {
		// TODO Auto-generated method stub
        	vis[3][3]=1;
            dfs(3,3);
            System.out.println(ans/4);
	}

		private static void dfs(int i, int j) {
			// TODO Auto-generated method stub
			
			if(i==0||j==0||i==6||j==6) 
			{
				ans++;
				return;
			}
			for(int k=0;k<4;k++)
			{
				if(i+dis[k][0]<=6&&i+dis[k][1]>=0&&j+dis[k][1]<=6&&j+dis[k][1]>=0)
				{
					if(vis[i+dis[k][0]][j+dis[k][1]]!=1)
					{
						vis[i+dis[k][0]][j+dis[k][1]]=1;
						vis[6-(i+dis[k][0])][6-(j+dis[k][1])]=1;
						dfs(i+dis[k][0],j+dis[k][1]);
						vis[i+dis[k][0]][j+dis[k][1]]=0;
						vis[6-(i+dis[k][0])][6-(j+dis[k][1])]=0;
					}
				}
			}
		}
   
}

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值