일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- MSA
- IT
- C
- JPA
- 자바
- 알고리즘
- spring webflux
- Galera Cluster
- 백준
- Data Structure
- MySQL
- 파이썬
- 운영체제
- mongoDB
- Java
- Kafka
- c언어
- Heap
- Proxy
- OS
- 자료구조
- 네트워크
- Algorithm
- design pattern
- 디자인 패턴
- JavaScript
- redis
- react
- Spring
- 컴퓨터구조
Archives
- Today
- Total
시냅스
백준 boj 3085 - 사탕 게임 (파이썬, python) 본문
https://www.acmicpc.net/problem/3085
브루트포스를 활용하여 문제를 해결하였다.
문제 제한 시간이 1초라 시간초과에 유의했으나,
애초에 입력값이 작아 o(n^4) 되는 나의 솔루션도 문제가 없는 것 같다.
풀이는 입력값을 받은 배열에 있는 모든 원소를
가로로 한 번 교체하여 최대값을 확인하고,
세로로 한 번 교체하여 최대값을 확인하였다.
다만 교체한 후에는 원상복귀하여 배열에 이상이 없게 해야했다.
그렇게 도출된 cnt와 result를 비교하여 더 큰 값을 결과값으로 도출하였다.
파이썬의 스왑은 언제나 감동적이다...
code
n = int(input())
result = 0
bombo = [list(input()) for _ in range(n)]
def check_bombo():
global result
for i in range(n): # 가로 맥스 카운팅
cnt = 1
for j in range(n - 1):
if bombo[i][j] == bombo[i][j + 1]:
cnt += 1
result = max(result, cnt)
else:
cnt = 1
for i in range(n): # 세로 맥스 카운팅
cnt = 1
for j in range(n - 1):
if bombo[j][i] == bombo[j + 1][i]:
cnt += 1
result = max(result, cnt)
else:
cnt = 1
for i in range(n):
for j in range(n - 1):
bombo[i][j], bombo[i][j + 1] = bombo[i][j + 1], bombo[i][j] # 가로 교체
check_bombo()
bombo[i][j + 1], bombo[i][j] = bombo[i][j], bombo[i][j + 1] # 원복
bombo[j][i], bombo[j + 1][i] = bombo[j + 1][i], bombo[j][i] # 세로 교체
check_bombo()
bombo[j + 1][i], bombo[j][i] = bombo[j][i], bombo[j + 1][i] # 원복
print(result)
'알고리즘' 카테고리의 다른 글
백준 boj 1107 - 리모컨 (파이썬, python) (0) | 2022.02.10 |
---|---|
백준 boj 1476 - 날짜 계산 (파이썬, python) (0) | 2022.02.10 |
백준 boj 2309 - 일곱 난쟁이 (파이썬, python) (0) | 2022.02.09 |
백준 boj 17425 - 약수의 합 (파이썬, python) (0) | 2022.02.08 |
백준 boj 6588 - 골드바흐의 추측 (파이썬, python) (0) | 2022.02.08 |
Comments