목록2024/03 (36)
미소를뿌리는감자의 코딩
이번주에는 대규모 트래픽에 대해서 깊게 배워보는 시간이 되었다. 모호했던 개념들이 점차 자리 잡아가며, 이해를 더 할 수 있어서 좋았다.
https://www.acmicpc.net/problem/15650 15650번: N과 M (2) 한 줄에 하나씩 문제의 조건을 만족하는 수열을 출력한다. 중복되는 수열을 여러 번 출력하면 안되며, 각 수열은 공백으로 구분해서 출력해야 한다. 수열은 사전 순으로 증가하는 순서로 출력해 www.acmicpc.net 1. 접근 방법 이번 문제는 DFS로 접근해야겠다는 냄새가 많이 나는 문제였다. def DFS(rows, m): if len(rows) == m: print(' '.join(map(str, rows))) return for i in range(1, n + 1, 1): if len(rows) == 0 or rows[-1] < i: rows.append(i) DFS(rows, m) n, m = ma..
https://www.acmicpc.net/problem/2630 2630번: 색종이 만들기 첫째 줄에는 전체 종이의 한 변의 길이 N이 주어져 있다. N은 2, 4, 8, 16, 32, 64, 128 중 하나이다. 색종이의 각 가로줄의 정사각형칸들의 색이 윗줄부터 차례로 둘째 줄부터 마지막 줄까지 주어진다. www.acmicpc.net 1. 접근 방법 2중 리스트로 값을 저장하고, 해당 리스트 합을 구한다. 즉, 종이에 적혀 있는 수들의 합을 구한다. 만약 그 수가 length**2 혹은 0 이 아니면, 종이가 파란색만 혹은 하얀색만 가지고 있는 것이 아니게 되어버릴 것이기 때문에 잘라줘야 한다. 이후, 다시 재귀적으로 종이를 4등분 한 후, 각각의 정사각형을 함수에 넣는다. 이후 해당 종이의 sum이..
https://www.acmicpc.net/problem/12015 12015번: 가장 긴 증가하는 부분 수열 2 첫째 줄에 수열 A의 크기 N (1 ≤ N ≤ 1,000,000)이 주어진다. 둘째 줄에는 수열 A를 이루고 있는 Ai가 주어진다. (1 ≤ Ai ≤ 1,000,000) www.acmicpc.net 1. 접근 방법 굉장히 익숙한 문제여서, 내가 이 문제를 제출을 안했었나? 하고 같은 방법으로 다시 풀고 제출했더니, 시간 초과가 되었다. https://potatoscatteringsmile.tistory.com/206 [백준 2024/03/23] 11053번 가장 긴 증가하는 부분 수열 https://www.acmicpc.net/problem/11053 11053번: 가장 긴 증가하는 부분 수..