-
[Programmers] JavaScript 알고리즘 | Lv.0 부분 문자열 이어 붙여 문자열 만들기► JS Algorithm/Programmers 2024. 1. 5. 20:58반응형
🔒 문제 설명
길이가 같은 문자열 배열 my_strings와 이차원 정수 배열 parts가 매개변수로 주어집니다. parts[i]는 [s, e] 형태로, my_string[i]의 인덱스 s부터 인덱스 e까지의 부분 문자열을 의미합니다. 각 my_strings의 원소의 parts에 해당하는 부분 문자열을 순서대로 이어 붙인 문자열을 return 하는 solution 함수를 작성해 주세요.
🔒 제한사항
- 1 ≤ my_strings의 길이 = parts의 길이 ≤ 100
- 1 ≤ my_strings의 원소의 길이 ≤ 100
- parts[i]를 [s, e]라 할 때, 다음을 만족합니다.
- 0 ≤ s ≤ e < my_strings[i]의 길이
🔒 입출력 예
my_strings parts result ["progressive", "hamburger", "hammer", "ahocorasick"] [[0, 4], [1, 2], [3, 5], [7, 7]] "programmers"
🔒 입출력 예 설명
입출력 예 #1
- 예제 1번의 입력을 보기 좋게 표로 나타내면 다음과 같습니다.
i my_strings[i] parts[i] 부분 문자열 0 "progressive" [0, 4] "progr" 1 "hamburger" [1, 2] "am" 2 "hammer" [3, 5] "mer" 3 "ahocorasick" [7, 7] "s" 각 부분 문자열을 순서대로 이어 붙인 문자열은 "programmers"입니다. 따라서 "programmers"를 return 합니다.
🔐 solution of mine
reduce()
slice()
const solution = (my_strings, parts) => console.log( my_strings.reduce( (acc, cur, i) => acc + cur.slice(parts[i][0], parts[i][1] + 1), "" ) ); solution( ["progressive", "hamburger", "hammer", "ahocorasick"], [ [0, 4], [1, 2], [3, 5], [7, 7], ] ); // expected output: "programmers"
🔐 solution of others
map()
slice()join()const solution = (my_strings, parts) => console.log( parts.map(([s, e], i) => my_strings[i].slice(s, e + 1)).join("") ); solution( ["progressive", "hamburger", "hammer", "ahocorasick"], [ [0, 4], [1, 2], [3, 5], [7, 7], ] ); // expected output: "programmers"
🔐 solution of others
reduce()
substring()
const solution = (my_strings, parts) => console.log( my_strings.reduce((acc, cur, idx) => { const [s, e] = parts[idx]; return acc + cur.substring(s, e + 1); }, "") ); solution( ["progressive", "hamburger", "hammer", "ahocorasick"], [ [0, 4], [1, 2], [3, 5], [7, 7], ] ); // expected output: "programmers"
🔐 solution of others
forEach()
substring()
const solution = (my_strings, parts) => { let answer = ""; parts.forEach( ([s, e], i) => (answer += my_strings[i].substring(s, e + 1)) ); return console.log(answer); }; solution( ["progressive", "hamburger", "hammer", "ahocorasick"], [ [0, 4], [1, 2], [3, 5], [7, 7], ] ); // expected output: "programmers"
반응형'► JS Algorithm > Programmers' 카테고리의 다른 글
[Programmers] JavaScript 알고리즘 | Lv.0 A 강조하기 (0) 2024.01.08 [Programmers] JavaScript 알고리즘 | Lv.0 특별한 이차원 배열 1 (1) 2024.01.08 [Programmers] JavaScript 알고리즘 | Lv.0 할 일 목록 (2) 2024.01.05 [Programmers] JavaScript 알고리즘 | Lv.0 배열의 원소만큼 추가하기 (0) 2024.01.05 [Programmers] JavaScript 알고리즘 | Lv.0 주사위 게임 1 (0) 2024.01.05