90-1. ad 제거하기

박은서's avatar
Mar 05, 2026
90-1. ad 제거하기
2026.03.05(THU)_90일차

1. 문제

문제 설명

문자열 배열 strArr가 주어집니다. 배열 내의 문자열 중 "ad"라는 부분 문자열을 포함하고 있는 모든 문자열을 제거하고 남은 문자열을 순서를 유지하여 배열로 return 하는 solution 함수를 완성해 주세요.

제한사항

  • 1 ≤ strArr의 길이 ≤ 1,000
    • 1 ≤ strArr의 원소의 길이 ≤ 20
    • strArr의 원소는 알파벳 소문자로 이루어진 문자열입니다.

입출력 예

strArr
result
["and","notad","abcd"]
["and","abcd"]
["there","are","no","a","ds"]
["there","are","no","a","ds"]

입출력 예 설명

입출력 예 #1
  • 1번 인덱스의 문자열인 "notad"는 부분 문자열로 "ad"를 가집니다. 따라서 해당 문자열을 제거하고 나머지는 순서를 유지하여 ["and","abcd"]를 return 합니다.
입출력 예 #2
  • "ad"가 부분 문자열로 들어간 문자열이 존재하지 않습니다. 따라서 원래 배열을 그대로 return 합니다.

2. 풀이

import java.util.*; class Solution { public String[] solution(String[] strArr) { List<String> list = new ArrayList<>(); for (String s : strArr) { if (s.contains("ad")) {} else list.add(s); } String[] answer = list.toArray(new String[0]); return answer; } }

3. 다른 사람의 풀이

import java.util.*; class Solution { public String[] solution(String[] strArr) { return Arrays.stream(strArr).filter(s -> !s.contains("ad")).toArray(String[]::new); } }
 
Share article