码迷,mamicode.com
首页 > 其他好文 > 详细

J - 棋盘问题

时间:2020-01-23 00:09:05      阅读:81      评论:0      收藏:0      [点我收藏+]

标签:需要   void   问题   lap   ring   自己   不能   size   while   

作为新手的我,看到该题很自然的没想到用搜索。。。通过大佬的讲解才有了个大体思想

【题意】给你一个棋盘nxm的,然后你的棋子只能放在有‘#’的位置,当然棋子的个数是自己定的,棋盘可放棋子的个数也是自己决定的。最后问棋子放在可用棋盘上的方案数。

【思路】由于要求摆放时任意的两个棋子不能放在棋盘中的同一行或者同一列。所以可以一行一行的找,从第一行开始,找到‘#’对其标记,从下一行开始找;代码过程中需要对同行同列的‘#’进行标记。

代码:

技术图片
#include<stdio.h>
#include<iostream>
#include<queue>
#include<string.h>
using namespace std;
 
char a[8][8];
int vis[8];//仅记录某一行是否有棋子 
int n,k;
int sum;

//dfs常用套路
void dfs(int x,int y){
    
    if(y==k){//判断边界 
        sum++;
        return ;
        //printf("%d-----\n",sum);     
    }
    if(x>=n)  return ; 
     for (int i = x; i < n; i++) {
        for (int j = 0; j < n; j++) {
            if (!vis[j] && a[i][j] == #) //棋子只能在可用的棋盘区域
            {
                vis[j] = 1;//标记本行的这一列不能在有棋子了
                dfs(i + 1, y + 1);//递归,进行下一行的计算
                vis[j] = 0;//结束了,本行位置没有棋子了
            }
        }
    }
    return ;
}

int main(){
    while(cin>>n>>k)
    {
        
        sum=0;
        memset(vis,0,sizeof(vis));
        memset(a,0,sizeof(a));
        if(n==-1&&k==-1)
        break;
    for(int i=0;i<n;i++)
    for(int j=0;j<n;j++)
    {cin>>a[i][j];
    }
    dfs(0,0);
    cout<<sum<<"\n";
    }
    return 0;
}
View Code

【注意】此题虽然很有dfs的模板,但是我觉得主要是标记的时候,只标记了该列的,走过该列后再标记为0;

且每次递归到达相应的总棋子数才会加一到下一行;其实也是回溯的方式

。。。。我都不知道我说了什么。

J - 棋盘问题

标签:需要   void   问题   lap   ring   自己   不能   size   while   

原文地址:https://www.cnblogs.com/WGD943/p/12229816.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!