문제 풀이
-
프로그래머스 - 양과 늑대 [Java]문제 풀이/프로그래머스 2024. 2. 26. 22:25
이 문제는 dfs를 이용해서 풀었다. 이 문제에서 핵심은 visited를 설정할 때 3중 배열로 설정해야 한다는 것이다. 한번 방문한 노드도 재방문할 수 있는 dfs이기 때문에 양과 늑대의 수도 매개변수에 포함시키고, 이들을 합한 3개의 매개변수에 대한 visited로 방문 여부를 판단하는 것이 핵심이다. 이 문제에서 굉장히 애를 먹은 부분이 있는데, if - else if - else 부분에서 코드 오류를 겨우 찾아냈다. 처음에는 if와 else if 의 조건 하나에 모든 요구사항을 다 넣었다. 그런데 이렇게 되면 if와 else if에 맞지 않는 조건이 else로 가버린다. 원래의 흐름은 양이냐 늑대냐 빈 노드냐 이기 때문에 정답이 나오지 않게 된다. 몇 시간의 삽질 끝에 겨우 오류를 찾아내 문제를 ..
-
프로그래머스 - 블록 이동하기 [Java]문제 풀이/프로그래머스 2024. 2. 26. 19:13
이 문제는 bfs를 이용해서 풀었다. 처음에는 재귀를 이용해서 풀었으나, 정답이 나오지 않았다. 로봇 구현까지는 문제 없었으나, 최솟값을 계산하는 과정에서 정답이 나오지 않았었다. 그래서 풀이를 참고했고, bfs를 이용해서 쉽게 풀 수 있었다. 요즘 자꾸 재귀로만 풀려고 하는 경향이 생겼는데, bfs를 잘 이용해야겠다. 결국 내가 아는 선에서 문제를 출제할 것이라는 생각을 가지고 문제에 임해야겠다. import java.util.*; class Solution { static final int RIGHT = 0; static final int UP = 1; static final int LEFT = 2; static final int DOWN = 3; static final int INF = 100000..
-
프로그래머스 - 양궁대회 [Java]문제 풀이/프로그래머스 2024. 2. 25. 23:12
이 문제는 백트래킹을 이용해서 푸는 문제이다. 처음에는 이 문제를 풀 때 apeech 보다 1 많은 화살로 한번에 빼는 방식으로 풀었으나 오답이 나왔다. 그래서 검색을 통해 그냥 백트래킹을 이용하는 것이 구현도 직관적이고 풀이도 쉽다는 사실을 발견했다. 처음 풀었던 방식의 문제점은 화살이 남는 경우에 대해 로직이 모호하다는 것이다. 마지막까지 도달했을 때 남은 화살을 전부 0점에 꽂아넣는 방식으로 구현했으나 오답이었다. 그냥 백트래킹은 당연히 시간 초과가 나기 때문에, 여러 가지 장치를 해주면 시간 안에 풀 수 있다. 먼저 start 매개변수를 두어 순서가 뒤바뀐 똑같은 결과를 만들지 않도록 순서를 강제한다. 그 다음 apeech보다 1만 많으면 되므로, ryan이 이미 화살이 더 많은 경우에는 cont..
-
프로그래머스 - 순위 검색 [Java]문제 풀이/프로그래머스 2024. 2. 25. 17:05
이 문제는 해시, 이분 탐색을 이용해서 풀었다. 처음에는 입력으로 주어지는 값들을 모은 Node라는 클래스를 만들고 점수로 오름차순 정렬한 뒤 점수로 한번 필터링하고, 조건에 맞는 것들을 순회하여 찾는 방식으로 구현했었다. 그러나 이 방법으로는 효율성을 통과할 수 없다. 이 문제에서 중요한 점은 언어, 직군, 경력, 소울푸드의 모든 경우의 수가 -를 포함해도 4 * 3 * 3 * 3 = 108개밖에 되지 않는 것을 파악하는 것이다. 따라서 그냥 쿼리에서 나올 수 있는 모든 조합에 대한 키에 대해 미리 저장해두고, info를 순회할 때에도 -를 주의하며 키 생성 후 집어넣고 쿼리에서 한번에 찾는 방식으로 구현하면 시간 내에 구현할 수 있다. import java.util.*; import java.io.*..
-
프로그래머스 - 혼자서 하는 틱택토 [Java]문제 풀이/프로그래머스 2024. 2. 24. 11:49
이 문제는 완전 탐색을 이용해서 풀었다. 격자가 3 x 3 인 틱택토를 하는 문제로, 격자의 크기가 작아 모든 경우의 수를 구한 뒤 비교하는 방식으로 풀었다. 한 가지 주의할 점은 play를 수행할 때 게임이 끝나는 경우에 왔다고 해서 return을 하면 모든 경우를 볼 수 없다. 따라서 continue로 다음 경우들을 체크해줘야 정답이 나온다. import java.util.*; class Solution { List snapshot = new ArrayList(); char[][] board = new char[3][3]; public int solution(String[] b) { init(); if (isSame(board, b)) { return 1; } play('O'); for (final ..
-
프로그래머스 - 숫자 블록 [Java]문제 풀이/프로그래머스 2024. 2. 22. 17:21
이 문제는 Map을 이용해서 풀었다. 도로의 길이가 10억이므로 배열로 만들면 메모리 초과가 나게 된다. 주목할 점은 end - begin이 5000밖에 안된다는 점이다. 따라서 해당 부분만 저장하면 된다는 생각을 했고, Map을 이용해서 해당 범위 안의 숫자들을 저장했다. 정직하게 반복문을 돌려 1부터 1,000만까지 계산하면 당연히 시간 초과가 난다. 1의 경우 2부터 10억까지를 루프를 돌리기 때문이다. 따라서 num * 2가 begin보다 작을 경우를 두어 이 때는 연산을 통해 한번에 시작 숫자를 찾아내야 한다. 위 부분만 구현해낼 수 있으면 한 번에 문제를 풀 수 있다. import java.util.*; class Solution { Map numbers = new HashMap(); int ..
-
프로그래머스 - 후보키 [Java]문제 풀이/프로그래머스 2024. 2. 19. 18:56
이 문제는 자료구조 및 구현 문제이다. 모든 속성의 길이가 최대 8까지이므로, 완전 탐색으로 시간 안에 구현이 가능하다. 먼저 모든 키의 경우의 수를 구하고, 각 경우에 대해 최소성과 유일성을 검증하는 방식으로 구현했다. 최소성과 유일성을 판단하는 로직이 상당히 까다롭지만, 구현을 해낸다면 문제는 쉽게 풀린다. import java.util.*; import java.io.*; class Solution { Set candidate = new HashSet(); String[][] table; int columnSize; int rowSize; public int solution(String[][] relation) { table = relation; rowSize = relation.length; co..
-
프로그래머스 - 과제 진행하기 [Java]문제 풀이/프로그래머스 2024. 2. 19. 16:56
이 문제는 자료구조를 이용한 문제이다. 처음에는 00:00부터 23:59를 분으로 바꾸어 0 ~ 1339 까지 루프를 돌려 문제를 풀었으나, 계속 오답이 나왔다. 그래서 자료 구조를 사용하여 문제를 풀었고, 정답을 맞출 수 있었다. import java.util.*; import java.io.*; class Solution { static final int MAX = 2000; Stack stopped = new Stack(); Queue tasks = new LinkedList(); public String[] solution(String[][] plans) { List temp = new ArrayList(); for (final String[] plan : plans) { final String ..