質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
for

for文は、様々なプログラミング言語で使われている制御構造です。for文に定義している条件から外れるまで、for文内の命令文を繰り返し実行します。

アルゴリズム

アルゴリズムとは、定められた目的を達成するために、プログラムの理論的な動作を定義するものです。

ループ

ループとは、プログラミングにおいて、条件に合致している間、複数回繰り返し実行される箇所や、その制御構造を指します

コードレビュー

コードレビューは、ソフトウェア開発の一工程で、 ソースコードの検査を行い、開発工程で見過ごされた誤りを検出する事で、 ソフトウェア品質を高めるためのものです。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

1回答

781閲覧

縦横二重のビット全探索について

kay_ventris4

総合スコア269

for

for文は、様々なプログラミング言語で使われている制御構造です。for文に定義している条件から外れるまで、for文内の命令文を繰り返し実行します。

アルゴリズム

アルゴリズムとは、定められた目的を達成するために、プログラムの理論的な動作を定義するものです。

ループ

ループとは、プログラミングにおいて、条件に合致している間、複数回繰り返し実行される箇所や、その制御構造を指します

コードレビュー

コードレビューは、ソフトウェア開発の一工程で、 ソースコードの検査を行い、開発工程で見過ごされた誤りを検出する事で、 ソフトウェア品質を高めるためのものです。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2021/04/20 07:29

#問題
イメージ説明
イメージ説明
AtCoder ABC173 C問題より

#方針
とりあえず、縦H行、横W列の計(2^(H + W))通りについて、与えられたボードを各パターンで白に塗りつぶし(最終的な黒を数えるのだから赤ではなく白で塗り戻すのも一緒)、それらを一度出力することで中身を確認したいです。

#入力 (以下の出力はこの入力に従う)

Python

12 3 2 2..# 3###

#コード

Python

1from itertools import product 2 3H, W, K = map(int, input().split()) 4 5board = [] 6for _ in range(H): 7 board.append(str(input())) 8 9_board = board.copy() 10 11for bith in list(product([0, 1], repeat = H)): 12 for bitw in list(product([0, 1], repeat = W)): 13 14 for indh, to_whitenh in enumerate(bith): 15 for indw, to_whitenw in enumerate(bitw): 16 17 if to_whitenh: 18 board[indh] = '.' * W 19 if to_whitenw: 20 for el in board: 21 el = list(el) 22 el[indw] = '.' 23 ''.join(el) 24 25 print(board) 26 27 for i in range(len(board)): 28 board[i] = _board[i]

#出力

Python

1['..#', '###'] 2['..#', '###'] 3['..#', '###'] 4['..#', '###'] 5['..#', '###'] 6['..#', '###'] 7['..#', '###'] 8['..#', '###'] 9['..#', '...'] 10['..#', '...'] 11['..#', '...'] 12['..#', '...'] 13['..#', '...'] 14['..#', '...'] 15['..#', '...'] 16['..#', '...'] 17['...', '###'] 18['...', '###'] 19['...', '###'] 20['...', '###'] 21['...', '###'] 22['...', '###'] 23['...', '###'] 24['...', '###'] 25['...', '...'] 26['...', '...'] 27['...', '...'] 28['...', '...'] 29['...', '...'] 30['...', '...'] 31['...', '...'] 32['...', '...']

#問題点
どうやら、縦H行についてのパターンは出来ているように見えます。しかし、横W列についてのビット全探索が全く出来ておらず、結果縦の2^2 = 4つのパターンしか出来ていません。if to_whitenwの箇所で横のビット全探索についても上手く出来たと思ったのですが、どのような箇所が理由で期待する結果とならないのでしょうか。素人質問にて恐縮ですが、ご教授のほどよろしくお願い申し上げます。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

ビット全探索ができてないわけじゃなくてビットパターンに対する出力をうまく作れてないだけです。
普通に二次元リストを使えばシンプルに書けます。

diff

1from itertools import product 2+from copy import deepcopy 3H, W, K = map(int, input().split()) 4 5board = [] 6for _ in range(H): 7- board.append(str(input())) 8+ board.append(list(input())) 9 10-_board = board.copy() 11+_board = deepcopy(board) 12 13for bith in list(product([0, 1], repeat = H)): 14 for bitw in list(product([0, 1], repeat = W)): 15 16 for indh, to_whitenh in enumerate(bith): 17 for indw, to_whitenw in enumerate(bitw): 18- if to_whitenh: 19- board[indh] = '.' * W 20- if to_whitenw: 21- for el in board: 22- el = list(el) 23- el[indw] = '.' 24- ''.join(el) 25+ if to_whitenh or to_whitenw: 26+ board[indh][indw] = 'W' 27 28 print(board) 29 30- for i in range(len(board)): 31- board[i] = _board[i] 32+ board = deepcopy(_board)

普通のcopyとdeepcopyの違いには気を付けてください。

投稿2021/04/20 08:42

yudedako67

総合スコア2047

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

kay_ventris4

2021/04/20 09:24

めちゃくちゃ分かり易かったです。 copyとdeepcopyの使い分けも理解することが出来ました。ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問