작성
·
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번째를 삭제하고 난 후 뒤에 있는 값들을 하나씩 앞으로 당기는 작업을 한다는 것을 명심하세요. 이 문제도 해결해야 정답이 나올겁니다.