인프런 커뮤니티 질문&답변

김민지열심히해님의 프로필 이미지
김민지열심히해

작성한 질문수

자바(Java) 알고리즘 문제풀이 입문: 코딩테스트 대비

6. 뒤집은 소수

2-6)런타임에러 질문입니다.

작성

·

179

·

수정됨

0


import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import java.util.Scanner;

public class Main {
	public String solution(String[] arr) { 
		String answer= "";

		ArrayList<Integer> newlist = new ArrayList<>();		
		
		for(int i=0; i<arr.length; i++) {
			StringBuffer sb = new StringBuffer(arr[i]);				
			newlist.add(Integer.parseInt(sb.reverse().toString()));
		}
		
		for(int i=0; i<newlist.size(); i++) {
			if((int)newlist.get(i)==1) {
				newlist.remove(i);
			}
			
		}
	
		
		
		for(int i=0; i<newlist.size(); i++) {			
			for(int j=2; j<newlist.get(i); j++) {
				if(newlist.get(i)%j==0) {
					newlist.remove(i);
				}
	
			}
		}
		
	
		
		for(int i=0; i<newlist.size(); i++) {
			answer += newlist.get(i)+ " ";
		}

		
		return answer;
	}
	
	
	public static void main(String[] args) {
		Main T = new Main(); 
	    Scanner kb=new Scanner(System.in);
	
	    
	    int N = kb.nextInt();
	    String[] arr = new String[N];
	    for(int i=0; i<N; i++) {
	    	arr[i] = kb.next();
	    }
	    

	    System.out.println(T.solution(arr));
	    
	    
	    return ;
	}
}

 

맨 처음에 string[]배열로 입력값을 받은후

stringbuffer을 이용해서 뒤집고, Integer.parseInt하면 0이 제거 되는 숫자화가 됩니다.

그 이후에 arraylist에 순서대로 담아서, 소수가 아니면 제거하는 방식으로 풀었는데

런타임에러가 나는 이유를 모르겠습니다.

답변 1

0

김태원님의 프로필 이미지
김태원
지식공유자

안녕하세요^^

런타임 에러는 위에 코드가 index out of range 에러를 내기 때문입니다.

1

21

위와 같이 입력해보세요. 아마 index out of range 에러가 날겁니다.

for(int i=0; i<newlist.size(); i++) {			
	for(int j=2; j<newlist.get(i); j++) {
		if(newlist.get(i)%j==0) {
			newlist.remove(i);
		}	
	}
}

위에 코드에서 에러가 나고 있습니다.

1

21

를 입력하고 일단 런타임 에러를 잡아보세요.

그리고 에러를 잡아 런타임에러는 나지 않아도 정답은 나오지 않을 겁니다. 왜냐하면 remove(i)는 i번째를 삭제하고 난 후 뒤에 있는 값들을 하나씩 앞으로 당기는 작업을 한다는 것을 명심하세요. 이 문제도 해결해야 정답이 나올겁니다.

 

김민지열심히해님의 프로필 이미지
김민지열심히해

작성한 질문수

질문하기