2023년 1월 1일
08:00 AM
Buffering ...

최근 글 👑

Lv0 JS 프로그래머스 #18 - 문자열로 변환, 수 조작하기 1, 길이에 따른 연산

2023. 8. 25. 21:44ㆍ프로그래머스 JS 코딩테스트
반응형

55. 문자열로 변환

 

문제 설명

  • 정수 n이 주어질 때, n을 문자열로 변환하여 return하도록 solution 함수를 완성해주세요.

제한사항

  • 1 ≤ n ≤ 10000

입출력 예시

  • 123을 문자열로 변환한 "123"을 return합니다.
  • 2573을 문자열로 변환한 "2573"을 return합니다.

풀이

const solution = n => n.toString();

// toString() 메서드로 문자열로 변환

 

56. 수 조작하기 1

 

문제 설명 

  • 정수 n과 문자열 control이 주어집니다. 
  • control은 "w", "a", "s", "d"의 4개의 문자로 이루어져 있으며, control의 앞에서부터 순서대로 문자에 따라 n의 값을 바꿉니다.
    • "w" : n이 1 커집니다. 
    • "s" : n이 1 작아집니다. 
    • "d" : n이 10 커집니다. 
    • "a" : n이 10 작아집니다. 
  • 위 규칙에 따라 n을 바꿨을 때 가장 마지막에 나오는 n의 값을 return 하는 solution 함수를 완성해 주세요.

제한사항 

  • -100,000 ≤ n ≤ 100,000 
  • 1 ≤ control의 길이 ≤ 100,000 
  • control은 알파벳 소문자 "w", "a", "s", "d"로 이루어진 문자열입니다.

입출력 예시 

  • 수 n은 control에 따라 다음과 같은 순서로 변하게 됩니다. 
  • 0 → 1 → 0 → 10 → 0 → 1 → 0 → 10 → 0 → -1 → -2 → -1 
  • 따라서 -1을 return 합니다.

풀이

const solution = (n, control) => {
    for(const check of control){
        if(check === "w") n += 1;
        else if(check === "s") n -= 1;
        else if(check === "d") n += 10;
        else if(check === "a") n -= 10;
    }
        return n;
}


// for..of를 통해 각 문자에 따른 식을 처리한 후 반환해준다.

 

57. 길이에 따른 연산

 

문제 설명 

  • 정수가 담긴 리스트 num_list가 주어질 때, 리스트의 길이가 11 이상이면 리스트에 있는 모든 원소의 합을 10 이하이면 모든 원소의 곱을 return하도록 solution 함수를 완성해주세요.

제한사항 

  • 2 ≤ num_list의 길이 ≤ 20 
  • 1 ≤ num_list의 원소 ≤ 9

입출력 예시 

  • 리스트의 길이가 13이므로 모든 원소의 합인 51을 return합니다.
  • 리스트의 길이가 4이므로 모든 원소의 곱인 120을 return합니다.

풀이

const solution = num_list => {
    let result = 1;
    if(num_list.length >= 11) {
        --result;
        for(const num of num_list){
            result += num;
        }
    } else {
        for(const num of num_list){
            result *= num;
        }
    }
    return result;
}

// result의 초기값은 1, 곱셈의 합이 0이 되지 않기 위함.
// 모든 합을 더하는 로직에서는 result에서 1을 빼고 시작.
// for..of 문을 이용하여 각 로직 수행

 

  • 정답률 높은 순부터 풀이
  • 매일 3 문항 풀이
반응형