저장을 습관화

프로그래머스 LV.0 인덱스 바꾸기 본문

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

프로그래머스 LV.0 인덱스 바꾸기

ctrs 2023. 9. 21. 11:36

프로그래머스 LV.0 인덱스 바꾸기

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

 

프로그래머스

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

programmers.co.kr

 

1. 문제 명

인덱스 바꾸기


2. 문제 설명

문자열 my_string과 정수 num1, num2가 매개변수로 주어질 때, my_string에서 인덱스 num1과 인덱스 num2에 해당하는 문자를 바꾼 문자열을 return 하도록 solution 함수를 완성해보세요.


3. 제한 사항

- 1 < my_string의 길이 < 100

- 0 ≤ num1, num2 < my_string의 길이

- my_string은 소문자로 이루어져 있습니다.

- num1 ≠ num2


4. 예시

my_string num1 num2 result
"hello" 1 2 "hlelo"
"I love you" 3 6 "I l veoyou"


5. 기본 제공 코드

function solution(my_string, num1, num2) {
    var answer = '';
    return answer;
}


6. 제출한 내 답

const solution = (my_string, num1, num2) => {
  let a = my_string[num1];
  let b = my_string[num2];

  return (
    my_string.slice(0, num1) +
    b +
    my_string.slice(num1 + 1, num2) +
    a +
    my_string.slice(num2 + 1)
  );
};

 

6-2. VSC에 작성한 내용

const solution = (my_string, num1, num2) => {
  let a = my_string[num1];
  let b = my_string[num2];

  return (
    my_string.slice(0, num1) +
    b +
    my_string.slice(num1 + 1, num2) +
    a +
    my_string.slice(num2 + 1)
  );
};

// 테스트
console.log(solution("hello", 1, 2)); // "hlelo"
console.log(solution("I love you", 3, 6)); // "I l veoyou"


7. 특이사항

솔직히 좀 억지로 풀었음

유치해 보여서 마음에 들지 않음


8. 다른 사람이 작성한 답

8-1.

function solution(my_string, num1, num2) {
    my_string = my_string.split('');
    [my_string[num1], my_string[num2]] = [my_string[num2], my_string[num1]];
    return my_string.join('');
}

 

8-2.

function solution(my_string, num1, num2) {
  let arr = my_string.split("");
  [arr[num1], arr[num2]] = [arr[num2], arr[num1]];
  return arr.join("");
}

배열 내 요소를 그 자리에서 바로바로 수정하는 것도 가능하구나..

 

8-3. splice

function solution(my_string, num1, num2) {
    var answer = '';

    let arr = my_string.split("");
    let tmp1 = my_string[num1];
    let tmp2 = my_string[num2];
    arr.splice(num1, 1, tmp2);
    arr.splice(num2, 1, tmp1);
    answer = arr.join("");

    return answer;
}

 

정답률 88% 문제 모두 해결..

남은 문제 Lv.0 81개, Lv.1 60개, Lv.2 104개..