문제 설명
문자열들이 담긴 리스트가 주어졌을 때, 모든 문자열들을 순서대로 합친 문자열을 꼬리 문자열이라고 합니다. 꼬리 문자열을 만들 때 특정 문자열을 포함한 문자열은 제외시키려고 합니다. 예를 들어 문자열 리스트 ["abc", "def", "ghi"]가 있고 문자열 "ef"를 포함한 문자열은 제외하고 꼬리 문자열을 만들면 "abcghi"가 됩니다.
문자열 리스트 str_list와 제외하려는 문자열 ex가 주어질 때, str_list에서 ex를 포함한 문자열을 제외하고 만든 꼬리 문자열을 return 하도록 solution 함수를 완성해주세요.
제한사항
- 2 <= str_list의 길이 <= 10
- 1 <= str_list의 원소의 길이 <= 10
- 1 <= ex의 길이 <= 5
입출력 예
str_list | ex | result |
["abc", "def", "ghi"] | "ef" | "abcghi" |
["abc", "bbc", "cbc"] | "c" | "" |
import java.lang.StringBuilder;
class Solution {
public String solution(String[] str_list, String ex) {
StringBuilder sb = new StringBuilder();
for (int i = 0; i < str_list.length; i++) {
if (!str_list[i].contains(ex)) {
sb.append(str_list[i]);
}
}
String answer = sb.toString();
return answer;
}
}
StringBuilder를 생성합니다. for문이 str_list의 길이만큼 순회합니다. if문에서 contains 메소드를 이용하여 str_list의 i번째 원소에 문자열 ex가 포함되어 있는지 확인합니다. 만약 포함되어 있지 않다면, append 메소드를 이용하여 sb에 str_list의 i번째 원소를 추가합니다. 문자열 더하기를 할 때처럼, 별도의 문자열 구분 없이 삽입될 것입니다.
answer에 반환하기 전 toString 메소드를 이용하여 sb를 변환합니다. 과정 없이 반환할 경우에는 sb에 있는 문자열 값이 출력되는 대신, 메모리에 저장된 주소를 반환합니다.
'프로그래머스 > Lv. 0(코딩 기초 트레이닝)' 카테고리의 다른 글
[프로그래머스 코딩테스트] l로 만들기(Java) (0) | 2023.05.13 |
---|---|
[프로그래머스 코딩테스트] 커피 심부름(Java) (0) | 2023.05.13 |
[프로그래머스 코딩테스트] 문자열 묶기(Java) (0) | 2023.05.12 |
[프로그래머스 코딩테스트] 배열 비교하기(Java) (0) | 2023.05.12 |
[프로그래머스 코딩테스트] 배열의 원소 삭제하기(Java) (0) | 2023.05.12 |