본문 바로가기
반응형

Algorithm45

백준 2798 블랙잭 - C++ 접근 N 개의 카드 중에서 3개의 카드를 뽑아 그 합이 M과 같거나 근접한 경우를 구해야 한다. 이번 문제는 뽑는 카드의 개수가 3개로 정해져 있어서 3중 for문으로 풀 수도 있지만 재귀문을 사용해도 된다. 성능은 조건만 잘 맞춰주면 3중 for문이 더 빠르긴 하다. N이 5라 할 때 처음 뽑을 수 있는 카드의 수는 5 그다음은 4 다음은 3이다. 카드의 개수는 N에 영향을 받으니 식으로 나타내면 N x (N-1) x (N-2)이다. #include #include using namespace std; int possibleCnt = 3, totalSum=0; int N, M; vector nums; void re(int idx, int start, int sum){ if(idx == possibleC.. 2020. 7. 21.
백준 1436 영화감독 숌 - C++ 접근 얼핏 보면 1666, 2666, 3666으로 증가폭이 1000으로 규칙성이 있어 보이지만 예외사항이 존재한다 6천번대로 진입하면 6660, 6661, 이런 식으로 규칙성에 예외사항이 생긴다. 약간 3,6,9 하면 30번대에 항상 박수를 치는 것과 비슷한 느낌이다. 그리고 N이 10,000까지다. 즉 N이 2일 때 1666인 걸 감안하면 N이 커지면 10666, 16660 뭐 이런 식의 시리즈도 생길 것이기 때문에 N이 커질수록 그에 맞는 규칙성을 파악하여 로직을 작성하는 것보다 최소한의 규칙(666을 포함)만 만족시키는 숫자를 지속적으로 찾게끔 로직을 만들어 주는 게 좋다. #include #include using namespace std; bool isThisEnd(int n){ string s.. 2020. 7. 21.
백준 1018 체스판 다시 칠하기 - C++ 접근 어떠한 M*N크기의 판이 있을 때 이 판을 8*8로 자를 수 있는 모든 경우의 수를 구한다. 각각의 8*8로 잘려진 판을 체스판으로 만들 때 다시 칠해야 하는 최소비용을 구해야 한다. 어떻게 구해야 할까? 우선, 체스판이 될 수 있는 조건은 맨 처음 칸 색깔이 검은색일 수도 있고 흰색일 수도 있다. 축소해서 생각해보자 체스판이 4*4라 했을때 WBWB BWBW BWBW WBWB WBWB BWBW BWBW WBWB 위와 같이 두가지가 나올 수 있다. 그렇다면 잘려진 판에서 맨 처음이 흰색으로 시작하는 체스판 그리고 검은색으로 시작하는 체스판 각각의 비용을 비교해 더 작은 값이 최소 값이 된다. #include #include using namespace std; string chess[50]; int.. 2020. 7. 20.
백준 2231 분해합 - C++ 접근 문제에서 보면 245는 256(245+2+4+5)의 생성자다 그런데 어떠한 N이 나왔을 때 N의 생성자를 알아내기 위한 규칙성을 찾기가 어렵다..어쩌면 없을지도 N이 2020일때 2020의 생성자는 2009인데 규칙성을 찾을 수가 없다. 따라서 브루트포스로 해결해야 하는 문제인데 숫자 1부터 높여가며 N의 생성자가 될 수 있는지 확인하는 과정을 거치면 O(N)이고 N은 백만보다 작으니 충분히 해볼만 하다. #include #include using namespace std; int makeSum(int num){ int result = num; string str = to_string(num); for(int i=0; i> N; for(int i=1; i 2020. 7. 20.