https://school.programmers.co.kr/learn/courses/30/lessons/181886
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
첫 번째 풀이에서 런타임에러가 발생하여 통과하지 못했다.
그 이유가 무엇인지 고민하다가 수정해서 2번째 코드에서 통과했다
2개의 차이점이 무엇인지 파악해야 개발을 할 때 도움이 될거라고 생각했다.
차이점
- 데이터 저장
- 1번은 배열에 직접 값을 할당함.
- 2번은 ArrayList로 동적으로 데이터를 추가하고 있다. ArrayList를 쓰면 동적으로 조절할 수 있다. - 배열 크기 지정
- 1번은 `(int) names.length % 5`로 지정했는데 나머지가 0이 되는 경우를 생각하지 못했다.
- 2번은 List를 사용하여 동적으로 크기가 조절되는 배열을 생성했다. ArrayList는 동적으로 배열의 크기가 조절되니 정확한 크기를 지정할 필요가 없다 - 결과 반환
- 1번 방식은 배열을 직접 반환한다.
- 2번은 toArray를 사용해서 배열로 변환하여 반환한다.
1. 첫 번째 풀이 - 런타임 에러 발생
class Solution {
public String[] solution(String[] names) {
String[] answer = new String[(int) names.length % 5] ;
int idx = 0;
for(int i = 0; i < names.length ; i+=5){
answer[idx] = names[i];
idx++;
}
return answer;
}
}
2. 두 번째 풀이 - 성공
import java.util.ArrayList;
import java.util.List;
class Solution {
public String[] solution(String[] names) {
List<String> list = new ArrayList<>();
for (int i = 0; i < names.length; i +=5){
list.add(names[i]);
}
return list.toArray(new String[0]);
}
}
'코드문제풀이 > JAVA' 카테고리의 다른 글
[자바] 햄버거 만들기 (0) | 2023.08.23 |
---|---|
[2023.08.22] 알고리즘 문제 풀이 / Stream 간략하게 알아보기 (0) | 2023.08.22 |
[자바] 대충 만든 자판 (0) | 2023.08.22 |
[자바] 둘만의 암호 (0) | 2023.08.22 |
[자바] 달리기 경주 (0) | 2023.08.22 |