DFS专题_POJ 1321 n皇后变形

本文介绍了一种算法,用于计算在n*n的棋盘上放置k个棋子的方法数量,棋子不能位于同一行或同一列,并且只能放置在标记为#的位置。通过深度优先搜索实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

原题链接

题意:n*n的格子里放k<=n个棋子(不再同一行和同一列)有多少方法。只有标 # 的地方能放棋子。

一道蠢题,太蠢了,不要看。

#include <iostream>
#include <algorithm>
#include <cstring>
#include <cstdio>
using namespace std;
int n,k;
char s[10][10];
int vis[10];
long long cnt;
long long ans;


void dfs(int x,int y,int cc)
{
    if(cc==k) {cnt++;return;}
    if(x>=n-1) return;
    for(int i=x+1;i<n;i++)
        for(int j=0;j<n;j++){
            if(s[i][j]=='#'&&!vis[j]){
                vis[j]=1;
                //cout<<"i"<<i+1<<" "<<j+1<<endl;
                dfs(i,j,cc+1);
                vis[j]=0;
            }
        }
}


int main()
{
    while(cin>>n>>k&&n!=-1&&k!=-1)
    {
        ans=0;
        for(int i=0;i<n;i++)
            scanf("%s",s[i]);
        for(int i=0;i<n;i++){
           for(int j=0;j<n;j++){
                if(s[i][j]=='#'){
                   // cout<<"j"<<i+1<<" "<<j+1<<endl;
                    memset(vis,0,sizeof(vis));
                    cnt=0;
                    vis[j]=1;
                    dfs(i,j,1);
                    ans+=cnt;
                }
            }
        }
        cout<<ans<<endl;

    }
    return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值