ABOUT ME

-

Today
-
Yesterday
-
Total
-
  • [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"

     


     

    반응형
Designed by Tistory.