짧은 단어만 골라 목록 만들기
자바스크립트 코딩테스트 문제로 array-selection-methods 주제를 연습해보세요. 난이도는 easy이며, 브라우저에서 바로 JavaScript로 풀이를 실행할 수 있습니다.
주어진 단어 목록에서 길이가 너무 긴 단어를 빼고, 조건을 만족하는 단어만 새 배열로 반환하는 문제입니다.
오늘의 메서드
Array.filter()
메서드 설명
Array.filter()는 배열의 각 요소를 검사해서, 조건을 만족하는 요소만 모은 새 배열을 만들어 주는 메서드입니다.
원본 배열은 바꾸지 않고, 통과한 요소들만 순서를 유지한 채 반환합니다.
기본 문법
arr.filter((item) => 조건식)
사용 예시
const words = ["cat", "elephant", "sun", "tree"];
words.filter((word) => word.length <= 3);
// ["cat", "sun"]
주의할 점
filter()는 조건을 만족한 요소들만 담은 새 배열을 반환합니다.- 조건을 만족하는 요소가 하나도 없으면 빈 배열
[]이 반환됩니다. - 원본 배열 자체는 변경되지 않습니다.
find()처럼 하나만 찾는 것이 아니라, 조건에 맞는 모든 요소를 고릅니다.
제한사항
1 <= words.length <= 1001 <= words[i].length <= 201 <= maxLength <= 20words[i]는 영어 소문자로만 이루어집니다.- 반환값은 길이가
maxLength이하인 단어들만 담은 배열입니다. - 반환 배열의 단어 순서는 입력 배열과 같아야 합니다.
예시
- 입력:
words = ["cat", "elephant", "sun", "tree"],maxLength = 3→ 출력:["cat", "sun"] - 입력:
words = ["a", "to", "code", "js"],maxLength = 2→ 출력:["a", "to", "js"] - 입력:
words = ["apple", "banana"],maxLength = 4→ 출력:[]
힌트
- 단어를 하나씩 보면서 길이가
maxLength이하인지 검사해 보세요. - 조건에 맞는 단어를 직접
push해도 되지만, 오늘은filter()로 더 간단하게 풀 수 있습니다. word.length <= maxLength조건식을 콜백 안에 넣으면 됩니다.
해설
이 문제의 핵심은 조건에 맞는 단어만 골라 새 배열을 만드는 것입니다.
예를 들어 words = ["cat", "elephant", "sun", "tree"], maxLength = 3이라면:
"cat"은 길이 3이므로 포함"elephant"는 길이 8이므로 제외"sun"은 길이 3이므로 포함"tree"는 길이 4이므로 제외
그래서 결과는 ["cat", "sun"]입니다.
이 상황은 Array.filter()와 아주 잘 맞습니다. 각 단어를 검사하면서 word.length <= maxLength가 true인 것만 남기면 되기 때문입니다.
function solution(words, maxLength) {
return words.filter((word) => word.length <= maxLength);
}
이 코드는:
words배열을 앞에서부터 순회하고- 각
word의 길이가maxLength이하인지 확인한 뒤 - 조건을 만족한 단어만 새 배열에 담아 반환합니다.
시간 복잡도는 각 단어를 한 번씩만 확인하므로 O(n)입니다.
초보자 입장에서는 filter()가 “조건에 맞는 것만 남긴다”는 감각을 익히기에 좋은 연습입니다.
코드 작성
starter code를 바탕으로 함수를 완성한 뒤 예제 테스트를 실행해보세요.
JavaScript
에디터 로딩 중...
커스텀 테스트
함수 인자를 JSON 배열 형태로 입력하세요. 예: [3, 5], [[1, 2, 3]]
아직 실행하지 않았습니다.
실행 결과
아직 실행하지 않았습니다.
예제 테스트를 실행하면 여기에서 결과를 확인할 수 있습니다.
댓글
문제 풀이 아이디어, 질문, 반례를 자유롭게 나눠보세요.