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

Instruction
在一个给定形状的棋盘(形状可能是不规则的)上面摆放棋子,棋子没有区别。要求摆放时任意的两个棋子不能放在棋盘中的同一行或者同一列,请编程求解对于给定形状和大小的棋盘,摆放k个棋子的所有可行的摆放方案C。
Input
输入含有多组测试数据。
每组数据的第一行是两个正整数,n k,用一个空格隔开,表示了将在一个n*n的矩阵内描述棋盘,以及摆放棋子的数目。 n <= 8 , k <= n
当为-1 -1时表示输入结束。
随后的n行描述了棋盘的形状:每行有n个字符,其中 # 表示棋盘区域, . 表示空白区域(数据保证不出现多余的空白行或者空白列)。
Output
对于每一组数据,给出一行输出,输出摆放的方案数目C (数据保证C<2^31)。
Sample
|input|output  |
|--|--|
| |  |
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 对象。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小梁说代码

你的鼓励是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值