Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- telegraf
- c3 축 가리기
- python os
- subporcess path
- CentOS7
- python popen
- c3 축 없애기
- 정규식 컴파일
- c3 step graph
- influxdb 설치
- centos pyhon 설치
- c3 second
- semanage
- snmp
- c3 초
- c++ 정규식
- gcc regex
- 1697
- grafana dashboard
- snmp test
- InfluxDB
- python subprocess
- 백준
- 정규식 활용
- regex_search
- selinux port 등록
- 정규식 문자열 출력
- linux시간으로 변경
- gcc 업데이트
- g++ 업데이트
Archives
- Today
- Total
리셋 되지 말자
[백준 1080] 체스판 다시 칠하기 - 브루트포스 본문
코드
def solution(arr):
answer = 2e9
# black 시작하는 체스판
b_arr = [
list('BWBWBWBW'),
list('WBWBWBWB'),
list('BWBWBWBW'),
list('WBWBWBWB'),
list('BWBWBWBW'),
list('WBWBWBWB'),
list('BWBWBWBW'),
list('WBWBWBWB')
]
# white 시작하는 체스판
w_arr = [
list('WBWBWBWB'),
list('BWBWBWBW'),
list('WBWBWBWB'),
list('BWBWBWBW'),
list('WBWBWBWB'),
list('BWBWBWBW'),
list('WBWBWBWB'),
list('BWBWBWBW'),
]
# height, width를 -7 까지만 탐색
for h in range(len(arr)-7):
for w in range(len(arr[0])-7):
b_cnt = 0
w_cnt = 0
# height+7, width+7 까지 탐색하며 b_arr, w_arr과 다르면 각자 카운트
for j in range(8):
for i in range(8):
if arr[h+j][w+i] != b_arr[j][i]:
b_cnt += 1
if arr[h+j][w+i] != w_arr[j][i]:
w_cnt += 1
# 최소값으로 업데이트
answer= min(answer, min(b_cnt, w_cnt))
print(answer)
h, w = map(int, input().split())
arr = []
for _ in range(h):
arr.append(list(input()))
solution(arr)
(i+j)%2 를 사용하면, b_arr w_arr 없이 풀 수 있다...
'알고리즘' 카테고리의 다른 글
[백준 1966] 프린터 큐 - 큐 (0) | 2022.01.18 |
---|---|
[백준 4949] 균형잡힌 세상 - 스택 (0) | 2022.01.18 |
[백준 10816] 숫자 카드 2 - 자료구조, 정렬(?), 이분탐색(?) (0) | 2022.01.14 |
[백준 2805] 나무 자르기 - 이분 탐색 (0) | 2022.01.13 |
[백준 7568] 덩치 - 브루트포스 (0) | 2022.01.10 |
Comments