标签:结束 java break out code ret 条件 scan 注意
Input
Output
Sample Input
2 1 #. .# 4 4 ...# ..#. .#.. #... -1 -1
Sample Output
2 1
注意:
不是每一行都要摆
代码:
import java.util.Arrays; import java.util.Scanner; public class Main{ static int n,k,cnt; static final int N=10; static char map[][]=new char[N][N]; static boolean vis[]=new boolean[N];//列 static void dfs(int r,int t){//r是行 t是第几个棋
//这种多个if条件的都要加上return,避免出错 if(t==k) { cnt++; return; } if(r>=n) return;
//当前行摆放或者不摆放 for(int i=0;i<n;i++){ if(!vis[i] && map[r][i]==‘#‘){ vis[i]=true; dfs(r+1,t+1); vis[i]=false; } } dfs(r+1,t); } public static void main(String[] args) { Scanner scan=new Scanner(System.in); while(scan.hasNext()){ n=scan.nextInt(); k=scan.nextInt(); if(n==-1 && k==-1) break; for(int i=0;i<n;i++) map[i]=scan.next().toCharArray(); Arrays.fill(vis, false); cnt=0; dfs(0,0); System.out.println(cnt); } } }
标签:结束 java break out code ret 条件 scan 注意
原文地址:https://www.cnblogs.com/qdu-lkc/p/12238790.html