剪邮票(java)

剪邮票
有12张连在一起的12生肖的邮票。现在你要从中剪下5张来,要求必须是连着的。(仅仅连接一个角不算相连)
请你计算,一共有多少种不同的剪取方法。
请填写表示方案数目的整数。
注意:你提交的应该是一个整数,不要填写任何多余的内容或说明性文字。

思路:组合+连通图

import java.util.LinkedList;
import java.util.Queue;

public class Text1 {
 static int[] a={1,2,3,4,5,6,7,8,9,10,11,12};
 static int[] num=new int[5];
 static int[] arr=new int[5];
 static int N=a.length;
 static int M=num.length;
 static int sum=0;
 public static void main(String[] args) {
  f(N,M);
  System.out.println(sum);
 }
 //组合
 private static void f(int n, int m) {
  int i,j;
   for(i=m;i<=n;i++) {
         num[m-1] = i-1;
         if(m>1)
                 f(i-1,m-1);
   else{
    for ( j = 0; j <=M-1; j++) {
     arr[j]=a[num[j]];
    }
    if(bfs(arr))
     sum++;
   }
  }
 }
 //相当于连通图解法
 private static boolean bfs(int[] arr2) {
  Queue<Integer> queue=new LinkedList<>();
  int[] dx={0,1,0,-1},dy={1,0,-1,0};
  int s=0,x,y;
  int[][] bfs=new int[4][5];
  for (int i = 0; i < 5; ++i) {
    x=(arr2[i]-1)/4;
    y=(arr2[i]-1)%4;
   bfs[x][y]=1;
  }
  queue.add(arr2[0]-1);
  while(!queue.isEmpty()){
   int q=queue.poll();
   for (int i = 0; i <4; ++i) {
     x=q/4+dx[i];
     y=q%4+dy[i];
    if(x<3 && y<4 && x>=0 && y>=0 && bfs[x][y]==1){
     queue.add(x*4+y);
     bfs[x][y]=0;
     s++;
    }
   }
  }
  if(s==5) return true;
  return false;
 }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值