백준 문제
-
백준 12865 (평범한 배낭) c++백준 문제 2022. 2. 3. 02:12
문제 12865번: 평범한 배낭 첫 줄에 물품의 수 N(1 ≤ N ≤ 100)과 준서가 버틸 수 있는 무게 K(1 ≤ K ≤ 100,000)가 주어진다. 두 번째 줄부터 N개의 줄에 거쳐 각 물건의 무게 W(1 ≤ W ≤ 100,000)와 해당 물건의 가치 V(0 ≤ V ≤ 1,000) www.acmicpc.net 유명한 knapsack 알고리즘 문제 입니다. n개의 물건들이 주어지고 각 물건들은 무게 w와 가치 v가 주어집니다. 가방은 최대 무게 k만큼 짐을 넣을 수 있습니다. 가치를 최대로 하면서 가방에 넣을 수 있는 물건들의 가치의 최댓값을 구하는 문제입니다. dp를 활용해서 문제를 해결하였습니다. dp[i][j] = i번째 물건을 확인하고 있고 가방의 최대 무게가 j일때 가방에 담긴 물건들의 최대..
-
백준 10986 (나머지 합) C++백준 문제 2022. 2. 1. 01:20
문제 10986번: 나머지 합 수 N개 A1, A2, ..., AN이 주어진다. 이때, 연속된 부분 구간의 합이 M으로 나누어 떨어지는 구간의 개수를 구하는 프로그램을 작성하시오. 즉, Ai + ... + Aj (i ≤ j) 의 합이 M으로 나누어 떨어지는 (i, j) www.acmicpc.net 배열 A(1) ~ A(n) 까지 주어지면 임의의 구간 [i, j] (A(i)+ ~ +A(j))에서의 합이 m으로 나누어 떨어지는 (i, j) 쌍의 개수를 구는 문제 입니다. 단순히 prefix sum을 이용해서 구간의 합인 [i, j]를 구하기 위해 prefixsum[j] - prefixsum[i-1]을 하게 되면 끝점 j를 잡고 이중 for문을 돌리게 되면 시간 복잡도가 O(n^2)이 나와서 시간초과가 나오게..
-
백준 11660 (구간 합 구하기 5) c++백준 문제 2022. 1. 28. 19:38
문제 11660번: 구간 합 구하기 5 첫째 줄에 표의 크기 N과 합을 구해야 하는 횟수 M이 주어진다. (1 ≤ N ≤ 1024, 1 ≤ M ≤ 100,000) 둘째 줄부터 N개의 줄에는 표에 채워져 있는 수가 1행부터 차례대로 주어진다. 다음 M개의 줄에는 네 www.acmicpc.net N X N 의 2차원 배열이 주어지고 (x1, y1) ~ (x2, y2) 까지의 합을 구하는 문제입니다. 예를 들어 n = 4 이고 (2, 2) ~ (3, 4) 구간의 합을 구하고 싶으면 1 2 3 4 2 3 4 5 3 4 5 6 4 5 6 7 빨간색 부분의 합을 구하면 됩니다. prefix sum 형태로 해결하였습니다 psum[x][y] = (1, 1) 부터 (x, y)의 합으로 정의 하였습니다. 예를 들어 psu..
-
백준 21318 (피아노 체조) c++백준 문제 2022. 1. 28. 17:35
문제 21318번: 피아노 체조 피아노를 사랑하는 시은이는 매일 아침 피아노 체조를 한다. 시은이는 N개의 악보를 가지고 있으며, 1번부터 N번까지의 번호로 부른다. 각 악보는 1 이상 109 이하의 정수로 표현되는 난이도를 www.acmicpc.net 피아노 악보 n개가 주어지고 각 n개의 악보마다 난이도가 주어집니다. 만약 i번째 악보가 i+1악보의 난이도보다 높다면 실수 합니다. 구간 x~y가 주어진다면 실수하는 횟수를 구하는 문제입니다. prefix sum을 이용하여 해결하였습니다. psum[i] = 1부터 i번째 까지 실수하는 횟수로 정의하였습니다. 구간 [x, y] = psum[y] - psum[x]로 구할 수 있습니다. 전체 코드입니다. HTML 삽입 미리보기할 수 없는 소스
-
백준 2042 (구간 합 구하기) c++백준 문제 2022. 1. 28. 02:13
문제 2042번: 구간 합 구하기 첫째 줄에 수의 개수 N(1 ≤ N ≤ 1,000,000)과 M(1 ≤ M ≤ 10,000), K(1 ≤ K ≤ 10,000) 가 주어진다. M은 수의 변경이 일어나는 횟수이고, K는 구간의 합을 구하는 횟수이다. 그리고 둘째 줄부터 N+1번째 줄 www.acmicpc.net n개의 숫자를 차례대로 입력받고 m번의 수 변경이 일어나고 k번의 구간의 합을 구하는 문제입니다. a가 1이면 b번째 수 위치를 c로 바꾸고 a가 2이면 b부터 c 구간의 합을 구하면 됩니다. 따라서 총 m+k번의 쿼리가 진행 됩니다. 단순히 prefix sum으로 해결하기에는 수를 계속 해서 바꿔주는 과정이 있기 때문에 더 효율적인 시/공간 복잡도로 이루어진 자료구조가 필요합니다. 따라서 Segm..
-
백준 16884 (나이트 게임) c++백준 문제 2022. 1. 26. 18:38
문제 16884번: 나이트 게임 첫째 줄에 테스트 케이스의 개수 T(1 ≤ T ≤ 100)가 주어진다. 둘째 줄부터 T개의 줄에 테스트 케이스가 한 줄에 하나씩 주어지며, 체스판의 크기 N(1 ≤ N ≤ 10,000)으로 이루어져 있다. www.acmicpc.net n * n 체스판에서 A와 B가 체스를 두는데 서로 체스 말을 '나이트'로 고정하고 번갈아가면서 나이트가 공격할 수 없는 공간에다가 나이트를 둡니다. 선공은 A가 먼저하고 승리하는 사람을 출력해주면 되는 문제입니다. 손으로 그림을 그려가면서 규칙성을 찾아보려 했지만 찾을 수 없었고 외부 블로그에서 영감을 얻어 해결하였습니다. 먼저 후공인 B가 이기는 최선의 방법을 구하는 것입니다. 결론 부터 얘기하면 B는 A가 두는 나이트의 점대칭 인곳에 체..
-
백준 17965 (Absolute Game) c++백준 문제 2022. 1. 26. 15:28
문제 17965번: Absolute Game Alice and Bob are playing a game. Alice has an array a of n integers, Bob has an array b of n integers. In each turn, a player removes one element of his array. Players take turns alternately. Alice goes first. The game ends when both arrays contain exactl www.acmicpc.net A와 B에게 길이가 같은 배열이 주어지면 A와 B는 서로 한번씩 배열의 숫자 1개를 제거할 수 있습니다. 가지고 있는 배열 중 마지막 원소 1개를 제외하고는 모두 제거 할 수 있는..
-
백준 12107 (약수 지우기 게임 1) c++백준 문제 2022. 1. 25. 16:05
문제 12107번: 약수 지우기 게임 1 N=4인 경우, A는 처음에 4,2,1을 지운다. 칠판에 남은 수는 3으로, B는 3을 지울 수밖에 없어 패배한다. www.acmicpc.net n이 주어지면 칠판에 1부터 n까지의 자연수를 쓰고 A와 B가 돌아가면서 칠판에 적혀진 자연수를 포함한 약수를 지우는 게임 입니다. 마지막 숫자를 지우는 사람이 지게 됩니다. 선공은 A부터 합니다. 1은 모든수의 약수입니다. 따라서 1은 항상 지워집니다. 만약 내가 이기는 판이면 그대로 게임을 진행하고 지는 판이면 맨 처음에 1 한개만 지웠다고 가정하고 상대판에게 턴을 넘기면 됩니다. 예를 들어 주어진 숫자가 5이면 1 2 3 4 5 먼저 A가 4(1, 2, 4)를 지우게 되면 3 5 다음 B가 3과 5 둘중 아무거나 지..