[프로그래머스 / JAVA] Level 1 같은 숫자는 싫어 (12906)
⏰ 2021-12-16 (목) 20:16:27
같은 숫자는 싫어
랭크 | 사용 언어 |
---|---|
Level 1 |
문제 설명
배열 arr
가 주어집니다. 배열 arr
의 각 원소는 숫자 0부터 9까지로 이루어져 있습니다. 이때, 배열 arr
에서 연속적으로 나타나는 숫자는 하나만 남기고 전부 제거하려고 합니다. 단, 제거된 후 남은 수들을 반환할 때는 배열 arr
의 원소들의 순서를 유지해야 합니다. 예를 들면,
arr = [ 1, 1, 3, 3, 0, 1, 1 ]
이면[ 1, 3, 0, 1
을 return 합니다.arr = [ 4, 4, 4, 3, 3 ]
이면[ 4, 3 ]
을 return 합니다.
배열 arr에서 연속적으로 나타나는 숫자는 제거하고 남은 수들을 return 하는 solution
함수를 완성해 주세요.
제한사항
- 배열
arr
의 크기 : 1,000,000 이하의 자연수 - 배열
arr
의 원소의 크기 : 0보다 크거나 같고 9보다 작거나 같은 정수
입출력 예
arr | answer |
---|---|
{ 1, 1, 3, 3, 0, 1, 1 } | { 1, 3, 0, 1 } |
{ 4, 4, 4, 3, 3 } | { 4, 3 } |
입출력 예 설명
입출력 예 #1, 2
문제의 예시와 같습니다.
풀이
임의의 정수 배열 arr
이 주어진다. 이 배열에서 동일하게 연속된 값이 있다면 전부 제거하고 하나만 남긴다. 이렇게 연속된 값을 전부 하나로 변경하여 반환하는 알고리즘을 구현해야한다.
배열 요소의 고유값을 요구하는 것이 아니므로, HashSet
을 쓰면 안된다. 일례로, 입력 1을 보면 { 1, 1, 3, 3, 0, 1, 1 }
-> { 1, 3, 0, 1 }
이 되는데, 1이 두 개가 있음을 확인할 수 있다.
정확히 몇 개의 요소가 생길지 알 수 없으므로 ArrayList
를 사용하는 것이 적절해보인다.
ArrayList
의 초기값으로 arr[0]
을 하나 넣어놓는다. 이후 arr[1]
부터 탐색하며, ArrayList
마지막에 들어있는 수와 비교한다.
- 만약
ArrayList
의 마지막과 다른 값일 경우, 연속되지 않았으므로ArrayList
에 넣는다. ArrayList
의 마지막과 같은 값일 경우, 연속된 값이므로 넘어간다.
코드
JAVA
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37
import java.util.ArrayList; /** * 같은 숫자는 싫어 클래스 * * @author RWB * @since 2021.12.13 Mon 13:32:56 */ class Solution { /** * 해답 반환 메서드 * * @param arr: [int[]] 0 ~ 9 사이의 숫자 배열 * * @return [int[]] 해답 */ public int[] solution(int[] arr) { ArrayList<Integer> list = new ArrayList<>(); list.add(arr[0]); int index = 1; for (int i = 1; i < arr.length; i++) { // list의 마지막 숫자와 같지 않을 경우 if (list.get(index - 1) != arr[i]) { index++; list.add(arr[i]); } } return list.stream().mapToInt(Integer::intValue).toArray(); } }
🏷️ 태그
# 프로그래머스
# 알고리즘
# JAVA(자바)
# Level 1
읽어주셔서 고마워요!
도움이 되셨다면, 공감이나 댓글을 달아주시는 건 어떤가요?
블로그 운영에 큰 힘이 됩니다.