POJ1321(DFS)

Problem Descrption

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

Input

输入含有多组测试数据。
每组数据的第一行是两个正整数,n k,用一个空格隔开,表示了将在一个n*n的矩阵内描述棋盘,以及摆放棋子的数目。 n <= 8 , k <= n
当为-1 -1时表示输入结束。
随后的n行描述了棋盘的形状:每行有n个字符,其中 # 表示棋盘区域, . 表示空白区域(数据保证不出现多余的空白行或者空白列)。

Output

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

Sample Input

2 1
#.
.#
4 4
...#
..#.
.#..
#...
-1 -1

Sample Output

2
1

问题链接:http://poj.org/problem?id=1321

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

Input

输入含有多组测试数据。
每组数据的第一行是两个正整数,n k,用一个空格隔开,表示了将在一个n*n的矩阵内描述棋盘,以及摆放棋子的数目。 n <= 8 , k <= n
当为-1 -1时表示输入结束。
随后的n行描述了棋盘的形状:每行有n个字符,其中 # 表示棋盘区域, . 表示空白区域(数据保证不出现多余的空白行或者空白列)。

Output

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

Sample Input

2 1
#.
.#
4 4
...#
..#.
.#..
#...
-1 -1

Sample Output

2
1

问题链接:http://poj.org/problem?id=1321

问题分析:DFS思想

AC代码:

#include<iostream>
using namespace std;
int n, k, ans;
char str[10][10];
int vis[100];void dfs(int r, int k)
{if(k==0)//判断边界,此时棋子已经放完{ans++;return;}for(int i=r; i<n; i++)//每次都从放过棋子下一行开始搜索,保证不重复{for(int j=0; j<n; j++){//循环保证行不重复,check保证列不重复if(str[i][j]=='.' || vis[j]==1)continue;//不满足条件直接跳过vis[j] = 1;//标记dfs(i+1, k-1);//继续下一次标记vis[j] = 0;//恢复初始状态}}
}int main(void)
{while(1){scanf("%d %d", &n, &k);getchar();if(n==-1 && k==-1) break;memset(str, '\0', sizeof(str));memset(vis, 0, sizeof(vis));ans = 0;for(int i=0; i<n; i++){for(int j=0; j<n; j++)str[i][j] = getchar();getchar();}dfs(0, k);//从第0行开始放,此时手中还剩k个棋子printf("%d\n", ans);}return 0;
}

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/330391.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

关于java流的几个概念:IO、BIO、NIO、AIO,有几个人全知道?

转载自 关于java流的几个概念&#xff1a;IO、BIO、NIO、AIO&#xff0c;有几个人全知道&#xff1f; 关于同步、阻塞的知识我之前的文章有介绍&#xff0c;所以关于流用到这些概念与之前多线程用的概念一样。 下面具体来看看java中的几种流 IO/BIO BIO就是指IO&#xff0c;即…

转:字符串和编码

转&#xff1a; https://www.liaoxuefeng.com/wiki/1016959663602400/1017075323632896 字符编码 我们已经讲过了&#xff0c;字符串也是一种数据类型&#xff0c;但是&#xff0c;字符串比较特殊的是还有一个编码问题。 因为计算机只能处理数字&#xff0c;如果要处理文本&…

HDU2067(卡特兰数)

Problem Descrption 小兔的叔叔从外面旅游回来给她带来了一个礼物&#xff0c;小兔高兴地跑回自己的房间&#xff0c;拆开一看是一个棋盘&#xff0c;小兔有所失望。不过没过几天发现了棋盘的好玩之处。从起点(0&#xff0c;0)走到终点(n,n)的最短路径数是C(2n,n),现在小兔又想…

JAVA元注解@interface详解(@Target,@Documented,@Retention,@Inherited)

转载自 JAVA元注解interface详解(Target,Documented,Retention,Inherited) jdk1.5起开始提供了4个元注解&#xff0c;用来定义自定义注解的注解&#xff0c;它们分别是&#xff1a; Target 指定注解使用的目标范围&#xff08;类、方法、字段等&#xff09;&#xff0c;其参考值…

转:字符编码笔记:ASCII,Unicode 和 UTF-8

转&#xff1a; http://www.ruanyifeng.com/blog/2007/10/ascii_unicode_and_utf-8.html 作者&#xff1a; 阮一峰 日期&#xff1a; 2007年10月28日 今天中午&#xff0c;我突然想搞清楚 Unicode 和 UTF-8 之间的关系&#xff0c;就开始查资料。 这个问题比我想象的复杂&am…

HDU2068(错列排序)

Problem Descrption 今年暑假杭电ACM集训队第一次组成女生队,其中有一队叫RPG,但做为集训队成员之一的野骆驼竟然不知道RPG三个人具体是谁谁。RPG给他机会让他猜猜&#xff0c;第一次猜&#xff1a;R是公主&#xff0c;P是草儿&#xff0c;G是月野兔&#xff1b;第二次猜&…

Java码农必须掌握的循环删除List元素的正确方法

转载自 Java码农必须掌握的循环删除List元素的正确方法 首先看下下面的各种删除list元素的例子 public static void main(String[] args) {List<String> list new ArrayList<>(Arrays.asList("a1", "ab2", "a3", "ab4",…

es dsl多条件组合查询(转)

【README】在不评分的情况下&#xff0c; 推荐使用filter 过滤查询&#xff0c;因为不评分&#xff0c;查询性能优于评分性能&#xff1b; 转&#xff1a;https://www.elastic.co/guide/cn/elasticsearch/guide/current/combining-queries-together.html 下面截图是我认为最有…

Java集合从菜鸟到大神演变

转载自 Java集合从菜鸟到大神演变 先来看一张集合概况图&#xff0c;这里从上到下列举了几个最经常用的集合 1、集合接口 java.util.Collection 是一个集合接口。它提供了对集合对象进行基本操作的通用接口方法。Collection接口在Java 类库中有很多具体的实现。Collection接口的…

转:Java并发编程与高并发解决方案(一)

转&#xff1a; https://blog.csdn.net/m0_37819279/article/details/81154126 首先介绍连接池 1&#xff1a;ExecutorService是Executor直接的扩展接口&#xff0c;也是最常用的线程池接口&#xff0c;我们通常见到的线程池定时任务线程池都是它的实现类。 2&#xff1a;Exe…

HDU1864(01背包)

Problem Descrption 现有一笔经费可以报销一定额度的发票。允许报销的发票类型包括买图书&#xff08;A类&#xff09;、文具&#xff08;B类&#xff09;、差旅&#xff08;C类&#xff09;&#xff0c;要求每张发票的总额不得超过1000元&#xff0c;每张发票上&#xff0c;单…

转:并发与并行的区别

转&#xff1a; https://www.jianshu.com/p/b11e251d3dc7 并发:一个处理器同时处理多个任务。&#xff08;concurrency&#xff09; 单个cpu逻辑上同时处理多个任务&#xff1b;并行:多个处理器或者是多核的处理器同时处理多个不同的任务. &#xff08;parallelism&#xff0…

面试必问-几种线程安全的Map解析

转载自 面试必问&#xff0d;几种线程安全的Map解析HashMap线程安全的吗&#xff1f;Java中平时用的最多的Map集合就是HashMap了&#xff0c;它是线程不安全的。看下面两个场景&#xff1a;1、当用在方法内的局部变量时&#xff0c;局部变量属于当前线程级别的变量&#xff0c;…

学习java多线程,这必须搞懂的这几个概念

转载自 学习java多线程&#xff0c;这必须搞懂的这几个概念&#xff0c;很重要。 同步和异步 同步&#xff0c;Synchronous&#xff0c;即调用方法开始&#xff0c;一旦调用就必须等待方法执行完返回才能继续下面的操作。 举个例子&#xff0c;你去银行ATM取钱&#xff0c;你必…

HDU1231(DP)

Problem Descrption 给定K个整数的序列{ N1, N2, ..., NK }&#xff0c;其任意连续子序列可表示为{ Ni, Ni1, ..., Nj }&#xff0c;其中 1 < i < j < K。最大连续子序列是所有连续子序列中元素和最大的一个&#xff0c; 例如给定序列{ -2, 11, -4, 13, -5, -2 }&…

8核、6核、4核、双核CPU是什么意思

转自&#xff1a; https://blog.csdn.net/he_jian1/article/details/41208915 对于初学者来说&#xff0c;CPU是什么、什么是双核、4核、6核、8核等。下面&#xff0c;就以上的问题&#xff0c;我们做出一一解答。 概念&#xff1a;CPU是什么、做什么用、一般CPU是接在哪里…

一个诡异的可见性问题

转载自 一个诡异的"可见性"问题 之前介绍过可见性的特性&#xff0c;最近做测试的时候发现了一个很诡异的问题&#xff0c;下面看看这三个例子。 test1&#xff1a; test1这个例子加了volatile&#xff0c;所以程序正确退出输出test1 end test2&#xff1a; test2这…

POJ3278(BFS)

Farmer John has been informed of the location of a fugitive cow and wants to catch her immediately. He starts at a point N (0 ≤ N ≤ 100,000) on a number line and the cow is at a point K (0 ≤ K ≤ 100,000) on the same number line. Farmer John has two mod…

转:认识cpu、核与线程

转自&#xff1a; https://www.cnblogs.com/-new/p/7234332.html 前言&#xff1a;作为一个后台开发人员&#xff0c;我想有必要了解这些基础知识。如果本文有不严谨或者疏忽的地方&#xff0c;请指正。 目录 认识cpu、核心与线程java多线程系列&#xff08;一&#xff09;之j…

java多线程中的死锁、活锁、饥饿、无锁都是什么鬼?

转载自 java多线程中的死锁、活锁、饥饿、无锁都是什么鬼&#xff1f; 死锁、活锁、饥饿是关于多线程是否活跃出现的运行阻塞障碍问题&#xff0c;如果线程出现了这三种情况&#xff0c;即线程不再活跃&#xff0c;不能再正常地执行下去了。 死锁 死锁是多线程中最差的一种情况…