월간 코드 챌린지 시즌1) 두 개 뽑아서 더하기

이상훈·2021년 12월 15일
0

프로그래머스

목록 보기
2/10

문제 설명

  • 정수 배열 numbers가 주어집니다. numbers에서 서로 다른 인덱스에 있는 두 개의 수를 뽑아 더해서 만들 수 있는 모든 수를 배열에 오름차순으로 담아 return 하도록 solution 함수를 완성해주세요.

제한사항

  • numbers의 길이는 2 이상 100 이하입니다.
    numbers의 모든 수는 0 이상 100 이하입니다..

입출력 예

inputoutput
[2,1,3,4,1][2,3,4,5,6,7]
[5,0,2,7][2,5,7,9,12]

JAVA 코드

import java.util.TreeSet;

class Solution {
    public int[] solution(int[] numbers) {
    	//트리셋 특징인 오름차순으로 삽입정렬되는 방식을 이용,
        TreeSet<Integer> set = new TreeSet<>();
        
        for(int i = 0; i < numbers.length-1; i++){
            for(int j = i+1; j < numbers.length; j++){
                set.add(numbers[i] + numbers[j]);
            }
        }
        
        //자료형 변환 방법 1 (성능)
        int[] answer = new int[set.size()];
        
        int idx = 0;
        for(Integer i : set){
            answer[idx] = i.intValue();
            idx++;
        }
        
        //자료형 변환 방법 2 (가독성)
        //answer = set.stream().mapToInt(Integer::intValue).toArray();
        
        return answer;
    }
}
profile
Hello!

0개의 댓글