首页 > 试题广场 >

小心火烛的歪

[编程题]小心火烛的歪
  • 热度指数:5520 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 512M,其他语言1024M
  • 算法知识视频讲解
\hspace{15pt}小歪正在一个占地 n \times m 大小的草地上研究他的燃放烟花计划。其中,一些位置已经堆放了杂物,为了便于观察,我们将给出一个 n \times m 大小的字符矩阵描述草地。其中,堆放了杂物的位置使用数字 1 标注;其余位置使用数字 0 标注。
\hspace{15pt}小歪已经做好了若干个烟花燃放计划,每一个计划均为一个 n \times m 大小的字符矩阵,一一对应草地的每一个方格。在这个计划中,将会被燃放烟花的地块使用数字 1 标注;没有烟花的地块使用数字 0 标注。
\hspace{15pt}他想选择一些计划同时实施,如果某个地块在任意一个计划中被标注为燃放,那么这个地块就会真的燃放上烟花。小歪想要知道,是否存在这样一种选择方法,使得全部有杂物位置均不会燃放烟花,而没有杂物的位置全部燃放上烟花;如果存在,请输出最少数量的计划。

输入描述:
\hspace{15pt}第一行输入三个整数 n,m,q \left( 1 \leqq n,m,q \leqq 7 \right) 代表草地的长、草地的宽、计划数量。
\hspace{15pt}此后 n 行,每行输入 m 个字符,代表草地初始状态。
\hspace{15pt}此后 n \times q 行,每行输入 m 个字符,用于描述计划。
\hspace{15pt}全部字符仅为数字 \texttt{0}\texttt{1}


输出描述:
\hspace{15pt}如果不存在满足要求的燃放方案,直接输出 -1

\hspace{15pt}否则,请按如下格式输出:
\hspace{15pt}第一行上输出一个整数 p \left( 0 \leqq p \leqq q \right) 代表使用到的计划数量。
\hspace{15pt}第二行输出 p 个整数代表你所选择的计划编号。编号即输入顺序,从 1 开始计数。

\hspace{15pt}如果存在多个解决方案,您可以输出任意一个,系统会自动判定是否正确。注意,自测运行功能可能因此返回错误结果,请自行检查答案正确性。
示例1

输入

2 2 1
00
01
11
10

输出

1
1
示例2

输入

7 7 5
1110111
1111111
1100001
0101000
1100001
1111111
1110111
0001000
0000000
0000000
1000001
0000000
0000000
0001000
0000000
0000000
0011100
0000000
0011100
0000000
0000000
0000000
0000000
0000010
0000111
0000010
0000000
0000000
0000000
0000000
0010000
0010000
0010000
0000000
0000000
0000000
0000000
0010000
0010111
0010000
0000000
0000000

输出

4
1 2 3 4

说明

\hspace{15pt}草地初始状态如下图所示。在这个样例中,选择 1,2,3,5 也是一个合法的答案。

头像 Leavery
发表于 2024-11-24 22:28:57
D题 bitset做法 直接枚举所有2^q种情况 因为数据范围很小 所以O(2^q*q*n*m)即可通过该题 #include <iostream> #include <bitset> using namespace std; int main() { int n,m, 展开全文
头像 ddb酱
发表于 2025-11-13 12:10:07
#include <bits/stdc++.h> using namespace std; #define endl "\n" #define pb push_back using vi = vector<int>; using vs = vector&l 展开全文
头像 夜晚的精灵
发表于 2025-09-03 17:33:58
import java.util.*; import java.math.BigInteger; // 注意类名必须为 Main, 不要有任何 package xxx 信息 public class Main { public static long initStatus; pu 展开全文
头像 WTcrazy
发表于 2025-11-16 04:09:24
import java.util.*; public class Main { static int M = 10; static int n, m, p, cnt = M, res; static StringBuilder cd = new StringBuilder( 展开全文
头像 Nanssu
发表于 2025-03-11 15:19:12
#include <iostream> #include <bits/stdc++.h> #include <set> #include <vector> using namespace std; void dfs(vector<int> 展开全文
头像 牛客336387193号
发表于 2025-03-26 19:53:05
用回溯法做,fireworks函数是回溯函数,如果填满了,且步数更少,就记录结果。重载了加减法方便一点。origin数组是记录的杂物,用于checkstone函数确保烟花没有放在杂物上面。 #include <iostream> #include<vector> using 展开全文
头像 在记录秋招的四郎很想去夏威夷
发表于 2025-06-23 21:11:57
from itertools import combinations def main(): n, m, q = map(int, input().split()) gs = "".join(input().strip().replace(" &qu 展开全文
头像 番禺小韭菜
发表于 2025-03-02 21:11:51
#include <iostream> #include <bitset> using namespace std; int main() { int n, m, q; cin >> n >> m >> q; bi 展开全文
头像 在拧螺丝的他很有趣
发表于 2025-03-04 13:42:34
import copy # 获取可能的组合 def get_list(lst): def b(start, path): if path: result.append(path) for i in range(start, len( 展开全文
头像 appley
发表于 2025-11-14 12:06:32
import java.util.Scanner; public class Main { static char[][] map = new char[8][8]; static int[][] fireworks = new int[8][8]; static char 展开全文