저장을 습관화

프로그래머스 LV.0 부분 문자열 이어 붙여 문자열 만들기 본문

코딩 테스트/프로그래머스 - 자바스크립트

프로그래머스 LV.0 부분 문자열 이어 붙여 문자열 만들기

ctrs 2023. 9. 18. 20:19

프로그래머스 LV.0 부분 문자열 이어 붙여 문자열 만들기

https://school.programmers.co.kr/learn/courses/30/lessons/181911

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

 

1. 문제 명

부분 문자열 이어 붙여 문자열 만들기


2. 문제 설명

길이가 같은 문자열 배열 my_strings와 이차원 정수 배열 parts가 매개변수로 주어집니다. parts[i]는 [s, e] 형태로, my_string[i]의 인덱스 s부터 인덱스 e까지의 부분 문자열을 의미합니다. 각 my_strings의 원소의 parts에 해당하는 부분 문자열을 순서대로 이어 붙인 문자열을 return 하는 solution 함수를 작성해 주세요.


3. 제한 사항

- 1 ≤ my_strings의 길이 = parts의 길이 ≤ 100

- 1 ≤ my_strings의 원소의 길이 ≤ 100

- parts[i]를 [s, e]라 할 때, 다음을 만족합니다.

- 0 ≤ s ≤ e < my_strings[i]의 길이


4. 예시

my_string parts result
["progressive", "hamburger", "hammer", "ahocorasick"] [[0, 4], [1, 2], [3, 5], [7, 7]] "programmers"


5. 기본 제공 코드

function solution(my_strings, parts) {
    var answer = '';
    return answer;
}


6. 제출한 내 답

const solution = (my_strings, parts) => {
  return parts
    .map((_, i) => {
      return my_strings[i].slice(parts[i][0], parts[i][1] + 1);
    })
    .join("");
};

 

6-2. VSC에 작성한 내용

// let a = "progressive";
// let b = "hamburger";
// let c = "hammer";
// let d = "ahocorasick";

// console.log(a.slice(0, 4 + 1));
// console.log(b.slice(1, 2 + 1));
// console.log(c.slice(3, 5 + 1));
// console.log(d.slice(7, 7 + 1));

const solution = (my_strings, parts) => {
  // let a = "";
  // for (i = 0; i < parts.length; i++) {
  //   // console.log(parts[i][0]);
  //   // console.log(parts[i][1] + 1);
  //   a += my_strings[i].slice(parts[i][0], parts[i][1] + 1);
  // }
  // return a;
  return parts
    .map((_, i) => {
      return my_strings[i].slice(parts[i][0], parts[i][1] + 1);
    })
    .join("");
};

// 테스트
console.log(
  solution(
    ["progressive", "hamburger", "hammer", "ahocorasick"],
    [
      [0, 4],
      [1, 2],
      [3, 5],
      [7, 7],
    ]
  )
);


7. 특이사항

없음


8. 다른 사람이 작성한 답

8-1. 좀 더 잘 쓰여진 map

function solution(my_strings, parts) {
    return parts.map(([s, e], i) => {
        return my_strings[i].slice(s, e + 1)
    }).join('')
}

요소를 배열로 넣을 수도 있구나

 

8-2 reduce

function solution(my_strings, parts) {
  return my_strings.reduce((result, str, i) => {
    const [s, e] = parts[i];
    return result + str.substring(s, e + 1);
  }, '');
}