[Python] 백준 알고리즘 온라인 저지 1436번 영화감독 숌 https://www.acmicpc.net/problem/1436 1436번: 영화감독 숌 666은 종말을 나타내는 숫자라고 한다. 따라서, 많은 블록버스터 영화에서는 666이 들어간 제목을 많이 사용한다. 영화감독 숌은 세상의 종말 이라는 시리즈 영화의 감독이다. 조지 루카스는 스타 www.acmicpc.net 처음에는 단순히 n-1을 앞에 붙이는 문제라고 생각하고 쉽다고 생각했다.😓 일단 문제를 풀기 위해서는 666이라는 숫자를 포함한 n번째로 작은 수를 찾는 것이라는 걸 이해해야 한다. ex) 첫 번째로 작은 666을 포함하는 수 = 666, 두 번째 = 1666, 300번째 = 110666 코드 n = int(input()) apo..
[Python] 백준 알고리즘 온라인 저지 1018번 체스판 다시 칠하기 https://www.acmicpc.net/problem/1018 1018번: 체스판 다시 칠하기 첫째 줄에 N과 M이 주어진다. N과 M은 8보다 크거나 같고, 50보다 작거나 같은 자연수이다. 둘째 줄부터 N개의 줄에는 보드의 각 행의 상태가 주어진다. B는 검은색이며, W는 흰색이다. www.acmicpc.net 처음에는 문제를 잘못 이해하여 쉬운 문제라고 생각하고 풀었다가 좌절을 맛봤다. 다른 분들의 풀이를 참고하여 풀 수 있었다. 이 문제에서도 브루트 포스를 사용하고 8x8 크기의 체스판을 모두 비교하여 가장 적은 칸을 칠하는 값을 구하는 문제이다. 코드 n, m = map(int, input().split()) chess..
[Python] 백준 알고리즘 온라인 저지 7568번 덩치 https://www.acmicpc.net/problem/7568 7568번: 덩치 우리는 사람의 덩치를 키와 몸무게, 이 두 개의 값으로 표현하여 그 등수를 매겨보려고 한다. 어떤 사람의 몸무게가 x kg이고 키가 y cm라면 이 사람의 덩치는 (x, y)로 표시된다. 두 사람 A 와 B의 덩 www.acmicpc.net 이번 문제에서 가장 헷갈렸던 점은 두 개의 수를 어떻게 비교하느냐 하는 점이었다. 문제를 풀어 나갈수록 점점 접근 방식이 다른 분들의 코드와 비슷해져 가는 것 같아 나름 뿌듯함을 느끼고 있습니다.😄 코드 n = int(input()) people = [] for _ in range(n): people.append(list(ma..
[Python] 백준 알고리즘 온라인 저지 2231번 분해합 https://www.acmicpc.net/problem/2231 2231번: 분해합 어떤 자연수 N이 있을 때, 그 자연수 N의 분해합은 N과 N을 이루는 각 자리수의 합을 의미한다. 어떤 자연수 M의 분해합이 N인 경우, M을 N의 생성자라 한다. 예를 들어, 245의 분해합은 256(=245+2+4+5)이 www.acmicpc.net 난이도는 쉬운 편으로 예외의 경우를 어떻게 처리해야 할지를 제외하면 어렵지 않게 for문과 리스트 내장 함수로 풀 수 있었다. 코드 n = int(input()) result = 0 for i in range(1, n+1): nums = list(map(int, str(i))) result = sum(nums..
[Python] 백준 알고리즘 온라인 저지 2798번 블랙잭 https://www.acmicpc.net/problem/2798 2798번: 블랙잭 첫째 줄에 카드의 개수 N(3 ≤ N ≤ 100)과 M(10 ≤ M ≤ 300,000)이 주어진다. 둘째 줄에는 카드에 쓰여 있는 수가 주어지며, 이 값은 100,000을 넘지 않는 양의 정수이다. 합이 M을 넘지 않는 카드 3장 www.acmicpc.net 브루트 포스 단계의 문제로 3장의 카드 조합을 모두 더하고 그 값이 m에 가장 근사한 값을 출력하는 문제이다. 문제의 난이도는 쉬운 편이었다. 이 문제 같은 경우는 블랙잭 게임을 구현하는 문제와도 같아서 의사 코드를 작성 후 코드를 작성했다. 코드 n, m = map(int, input().split())..