【Java每日一题,深度搜索dfs】棋盘问题

简介: 【Java每日一题,深度搜索dfs】棋盘问题

Instruction

在一个给定形状的棋盘(形状可能是不规则的)上面摆放棋子,棋子没有区别。要求摆放时任意的两个棋子不能放在棋盘中的同一行或者同一列,请编程求解对于给定形状和大小的棋盘,摆放k个棋子的所有可行的摆放方案C。

Input

输入含有多组测试数据。

每组数据的第一行是两个正整数,n k,用一个空格隔开,表示了将在一个n*n的矩阵内描述棋盘,以及摆放棋子的数目。 n <= 8 , k <= n

当为-1 -1时表示输入结束。

随后的n行描述了棋盘的形状:每行有n个字符,其中 # 表示棋盘区域, . 表示空白区域(数据保证不出现多余的空白行或者空白列)。

Output

对于每一组数据,给出一行输出,输出摆放的方案数目C (数据保证C<2^31)。

Sample

Answer

import java.util.Scanner;
import javax.sound.midi.SoundbankResource;
/**
 * @author liangyuanshao
 * @date 2022/4/21 - 17:46
 */
public class Main {
  static Boolean[][] arr;
  static int n,k;
  static int count=0;
  public static void main(String[] args) {
    Scanner s=new Scanner(System.in);
    while (true){
       n=s.nextInt(); k=s.nextInt();
      if(n!=-1){
        arr=new Boolean[n][n];
        for(int i=0;i<n;i++){
          String temp=s.next();
          for(int j=0;j<temp.length();j++){
            arr[i][j]=temp.charAt(j)=='#';
          }
        }
        count=0;
        dfs(0,new boolean[n],k);
        System.out.println(count);
      }else {
        break;
      }
    }
    s.close();
  }
  public static void dfs(int row,boolean[] col,int num){
    if(num==0){
      count++;
      return;
    }
    if(row==n){
      return ;
    }
    dfs(row+1,col,num);
    for(int j=0;j<n;j++){
      if(arr[row][j]&&!col[j]){
        col[j]=true;
        dfs(row+1,col,num-1);
        col[j]=false;
      }
    }
  }
}

Experience

Java函数是传值还是传引用的问题,函数里面修改的结果,会不会影响调用者

比如说,下面那行加红框的代码为什么要存在?


1.基本变量就是传递的引用,不改变调用者本身,像int,boolean,float等

2.对象就是传递的引用,函数和调用者都是操作的同一个对象。因为数组是对象,所以上面要对col数组修改后,再修改回来

3.但是String比较特别,虽然它是对象,但是仍然传递的是引用,因为String是用final修饰,默认不可修改。函数传递的时候,其实是另开了一个空间传递了相同的String 对象。


相关文章
|
5月前
|
存储 Java
百度搜索:蓝易云【Java语言之float、double内存存储方式】
由于使用IEEE 754标准进行存储,float和double类型可以表示非常大或非常小的浮点数,并且具有一定的精度。然而,由于浮点数的特性,它们在进行精确计算时可能会存在舍入误差。在编写Java程序时,需要注意使
60 0
|
3月前
|
算法 Java
BFS(广度搜索|宽度搜索)无向图遍历(JAVA手把手深入解析)
BFS(广度搜索|宽度搜索)无向图遍历(JAVA手把手深入解析)
48 0
|
3月前
|
数据采集 算法 Java
DFS(深度搜索)无向图遍历(JAVA手把手深入解析)
DFS(深度搜索)无向图遍历(JAVA手把手深入解析)
47 0
|
3月前
|
Java Docker 容器
百度搜索:蓝易云【Docker使用之java项目工程的部署】
通过以上步骤,你已经成功在Docker中部署了Java项目工程。这样可以确保你的应用在不同环境中具有一致的运行结果,并且方便地进行部署和管理。
39 7
|
4月前
|
Rust 索引
Rust 编程小技巧摘选(5)
Rust 编程小技巧摘选(5)
43 0
Rust 编程小技巧摘选(5)
|
4月前
|
C++ Java Go
Java每日一练(20230428) 搜索旋转排序数组、栈实现队列、平方根
Java每日一练(20230428) 搜索旋转排序数组、栈实现队列、平方根
47 0
Java每日一练(20230428) 搜索旋转排序数组、栈实现队列、平方根
|
4月前
|
Java Go C++
Java每日一练(20230421) 整数排列、数组排序、单词搜索
Java每日一练(20230421) 整数排列、数组排序、单词搜索
25 0
Java每日一练(20230421) 整数排列、数组排序、单词搜索
|
4月前
|
Java Go C++
Java每日一练(20230417) N 皇后、搜索二维矩阵、发奖金问题
Java每日一练(20230417) N 皇后、搜索二维矩阵、发奖金问题
26 0
Java每日一练(20230417) N 皇后、搜索二维矩阵、发奖金问题
|
5月前
|
Java
Java实现1.指定关键字搜索 2.指定后缀名搜索 3.文件/文件夹复制
Java实现1.指定关键字搜索 2.指定后缀名搜索 3.文件/文件夹复制
26 1
|
5月前
|
Java Python
百度搜索:蓝易云【Java执行Python代码的两种方法(Jython与ProcessBuilder)】
通过使用Jython或ProcessBuilder,您可以在Java中执行Python代码并与两种编程语言进行交互。选择哪种方法取决于您的需求和偏好。请根据实际情况选择适合您的项目的方法。
42 0