런타임에러라고 뜨는데 어디서 잘못된 걸까요?
263
작성한 질문수 1
board의 값을 map으로 저장했습니다. map<몇번째 칸, 저장된 인형들>
map의 key에 해당하는 value는 stack으로 저장했습니다.
찾아보니 테스트 케이스 5번이 N번 째 줄의 인형을 쌓을 때 0 0 0 1 2 3 이런 식으로 쌓이는 경우뿐 아니라 0 1 0 2 3 같은 경우도 있다고 하네요. 하지만 이건 문제에 따로 명시되지 않은 부분이고 보통 인형 쌓기라고 하면 공백 없이 차곡차곡 쌓이는 걸로 생각해서 코드를 짰습니다.
위의 테스트 케이스를 제외하고는 그럼 통과가 돼야 하는데 아예 런타임에러로 뜨는 이유를 못 찾고 있습니다..
어떤 문제 때문인지 알려주시면 감사하겠습니다!
package programmers.level0;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.HashMap;
import java.util.Map;
import java.util.Stack;
import java.util.StringTokenizer;
public class Main{
private static int solution(int size, int[][] board, int moveSize, int[] moves) {
int answer = 0; // 삭제된 인형 수
Map<Integer, Stack<Integer>> map = new HashMap<>(); // 인형뽑기 기계(몇번째줄에 어떤 인형이 있는지 저장)
// 입력받은 2차원 배열을 col별로 stack으로 저장해서 map에 저장
// 0값은 stack에 저장X
for (int col = 1; col <= size; col++) {
Stack<Integer> stack = new Stack<>();
for (int row = size; row > 0; row--) {
if (board[row][col] == 0) break;
stack.push(board[row][col]);
}
map.put(col, stack);
}
Stack<Integer> basket = new Stack<>();
for (int i = 0; i < moveSize; i++) {
Stack<Integer> stack = map.get(moves[i]);
if (!stack.isEmpty()) {
if (!basket.isEmpty() && stack.peek() == basket.peek()) {
basket.pop();
stack.pop();
answer += 2;
} else {
basket.push(stack.pop());
}
}
}
return answer;
}
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
StringTokenizer st = new StringTokenizer(br.readLine());
int size = Integer.parseInt(st.nextToken());
int[][] board = new int[size + 1][size + 1];
for (int i = 1; i <= size; i++) {
st = new StringTokenizer(br.readLine());
for (int j = 1; j <= size; j++) {
board[i][j] = Integer.parseInt(st.nextToken());
}
}
int moveSize = Integer.parseInt(br.readLine());
int[] moves = new int[moveSize];
st = new StringTokenizer(br.readLine());
for (int i = 0; i < moveSize; i++) {
moves[i] = Integer.parseInt(st.nextToken());
}
System.out.println(solution(size, board, moveSize, moves));
}
}
답변 1
안녕하세요. 바뀐 채점사이트 관련해서 문의드립니다.
0
25
1
갑자기 채점 사이트가 바뀌었어요
0
30
1
문제 리스트 페이지
0
26
1
채점 사이트 관련 질문드립니다
0
23
1
봉우리 문제 질문입니다
0
80
2
씨름 선수 문제에서 각 선수의 몸무게나 키가 같을 수도 있다면?
0
64
0
이 코드랑 영상 코드중에 뭐가 더 좋은 코드인가요?
0
71
0
가중치 방향 그래프에서 가중치가 0인 간선을 표현하는 방법
0
67
1
좌표 정렬 문제 이 코드가 왜 틀린지 모르겠습니다 ㅠㅠ
0
84
2
6-7 강의에서
0
47
1
6-6. 장난꾸러기 질문 있습니다.
0
44
1
강의 수강후 코딩테스트
0
108
1
answer 변수 사용 여부
0
43
1
2중 for문
1
84
2
2-11. 임시반장정하기 (Runtime Error)
0
63
1
혹시 LinkedList 같은 자료 구조들은 따로 배우지 않나요?
0
70
1
이런 풀이는 어떨까요
0
42
1
자바 스트림 방식의 효율성 질문 드립니다.
0
57
1
알고리즘 자료 구조들..
0
61
1
StringBuilder vs BufferdWriter
0
47
1
원더랜드(프림)
0
49
1
이런 코드는 어떤가요?
0
59
1
bfs 풀이
0
57
1
병합정렬
0
55
1





