본문 바로가기

Algorithm/Programers - Java

[프로그래머스(Java)] 배열의 원소 삭제하기 / anyMatch()

 

Level. 0

 

문제

정수 배열 arr과 delete_list가 있습니다. 
arr의 원소 중 delete_list의 원소를 모두 삭제하고 남은 원소들은 기존의 arr에 있던 순서를 유지한 배열을 return 하는 solution 함수를 작성해 주세요.

* 제한사항
- 1 ≤ arr의 길이 ≤ 100
- 1 ≤ arr의 원소 ≤ 1,000
- arr의 원소는 모두 서로 다릅니다.
- 1 ≤ delete_list의 길이 ≤ 100
- 1 ≤ delete_list의 원소 ≤ 1,000
- delete_list의 원소는 모두 서로 다릅니다.

 

풀이 1.

import java.util.List;
import java.util.ArrayList;

class Solution {
    public int[] solution(int[] arr, int[] delete_list) {

        List<Integer> list = new ArrayList<>();
        for( int i : arr){
            list.add(i);
        }
        
        for(int d : delete_list){
            list.remove((Integer)d);
        }
        
        int[] answer = new int[list.size()];
        
        for(int i=0; i<answer.length; i++){
            answer[i] = list.get(i);
        }
        
        return answer;

    }
}

 

 

풀이2. stream

import java.util.stream.*;

class Solution {
    public int[] solution(int[] arr, int[] delete_list) {

        return IntStream.of(arr).filter(i -> !IntStream.of(delete_list).anyMatch(j -> j == i)).toArray();
        
    }
}

 


https://school.programmers.co.kr/learn/courses/30/lessons/181844?language=java

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr