오늘 공부한 내용 📝

  • 자바스크립트 코딩테스트 입문 문제 풀이 완

궁금한 내용 / 부족한 내용 🧐

  • 자바스크립트 코딩테스트 레벨 1
  • 자바스크립트 코딩테스트 레벨 2

느낀 점 🤔

  • 꾸준히 하니까 좋았다.
  • 매일 분량을 정해주고, 열람 못하게 하고, 또 스스로 블로그에 포스팅하면서 루틴을 확립할 수 있었다.

'✒️ Study Log > ⬜ Today I Learned' 카테고리의 다른 글

[TIL - 230306]  (0) 2023.03.06
[TIL - 230305]  (0) 2023.03.06
[TIL - 230228]  (0) 2023.03.06
[TIL - 230227]  (0) 2023.03.05
[TIL - 230226]  (0) 2023.03.05

🌠 문제

등차수열 혹은 등비수열 common이 매개변수로 주어질 때, 마지막 원소 다음으로 올 숫자를 return 하도록 solution 함수를 완성해보세요.

🌠 제한사항

  • 2 < common의 길이 < 1,000
  • -1,000 < common의 원소 < 2,000
  • common의 원소는 모두 정수입니다.
  • 등차수열 혹은 등비수열이 아닌 경우는 없습니다.
  • 등비수열인 경우 공비는 0이 아닌 정수입니다.

🌠 입출력 예

common result
[1, 2, 3, 4] 5
[2, 4, 8] 16

🌠 입출력 예 설명

입출력 예 #1

  • [1, 2, 3, 4]는 공차가 1인 등차수열이므로 다음에 올 수는 5이다.

입출력 예 #2

  • [2, 4, 8]은 공비가 2인 등비수열이므로 다음에 올 수는 16이다.

🧞 풀이

function solution(common) {
    let isWhat = '';
    // 등차, 등비 판단
    if (common[1] - common[0] != common[2] - common[1]) {
        isWhat = '등비';
    } else {
        isWhat = '등차';
    }
    if (isWhat === '등비') {
        return common[common.length-1] * common[1] / common[0]; 
    } else {
        return common[common.length-1] + common[1] - common[0];
    }
}

🌠 문제

연속된 세 개의 정수를 더해 12가 되는 경우는 3, 4, 5입니다. 두 정수 num과 total이 주어집니다. 연속된 수 num개를 더한 값이 total이 될 때, 정수 배열을 오름차순으로 담아 return하도록 solution함수를 완성해보세요.

🌠 제한사항

  • 1 ≤ num ≤ 100
  • 0 ≤ total ≤ 1000
  • num개의 연속된 수를 더하여 total이 될 수 없는 테스트 케이스는 없습니다.

🌠 입출력 예

num total result
3 12 [3, 4, 5]
5 15 [1, 2, 3, 4, 5]
4 14 [2, 3, 4, 5]
5 5 [-1, 0, 1, 2, 3]

🌠 입출력 예 설명

입출력 예 #1

  • num = 3, total = 12인 경우 [3, 4, 5]를 return합니다.

입출력 예 #2

  • num = 5, total = 15인 경우 [1, 2, 3, 4, 5]를 return합니다.

입출력 예 #3

  • 4개의 연속된 수를 더해 14가 되는 경우는 2, 3, 4, 5입니다.

입출력 예 #4

  • 설명 생략

🧞 풀이

function solution(num, total) {
    let answer = [];
    if (num % 2 != 0) {
        let a = parseInt(total / num);
        for (let i = a - parseInt(num/2); i <= a + parseInt(num/2); i++) {
            answer.push(i);
        }   
    } else {
        let a = parseInt(total / num);
        for (let i = a - parseInt(num/2) + 1; i <= a + parseInt(num/2); i++) {
            answer.push(i);
        }
    }
    return answer;
}

🌠 문제

머쓱이는 큰 종이를 1 x 1 크기로 자르려고 합니다. 예를 들어 2 x 2 크기의 종이를 1 x 1 크기로 자르려면 최소 가위질 세 번이 필요합니다.

정수 M, N이 매개변수로 주어질 때, M x N 크기의 종이를 최소로 가위질 해야하는 횟수를 return 하도록 solution 함수를 완성해보세요.

🌠 제한사항

  • 0 < M, N < 100
  • 종이를 겹쳐서 자를 수 없습니다.

🌠 입출력 예

M N result
2 2 3
2 5 9
1 1 0

🌠 입출력 예 설명

입출력 예 #1

  • 본문과 동일합니다.

입출력 예 #2

  • 가로 2 세로 5인 종이는 가로로 1번 세로로 8번 총 가위질 9번이 필요합니다.

입출력 예 #3

  • 이미 1 * 1 크기이므로 0을 return 합니다.

🧞 풀이

function solution(M, N) {
    return M * N - 1;
}
더보기

🌠 문제

문자열 "hello"에서 각 문자를 오른쪽으로 한 칸씩 밀고 마지막 문자는 맨 앞으로 이동시키면 "ohell"이 됩니다. 이것을 문자열을 민다고 정의한다면 문자열 A와 B가 매개변수로 주어질 때, A를 밀어서 B가 될 수 있다면 밀어야 하는 최소 횟수를 return하고 밀어서 B가 될 수 없으면 -1을 return 하도록 solution 함수를 완성해보세요.

🌠 제한사항

  • 0 < A의 길이 = B의 길이 < 100
  • A, B는 알파벳 소문자로 이루어져 있습니다.

🌠 입출력 예

A B result
"hello" "ohell" 1
"apple" "elppa" -1
"atat" "tata" 1
"abc" "abc" 0

🌠 입출력 예 설명

입출력 예 #1

  • "hello"를 오른쪽으로 한 칸 밀면 "ohell"가 됩니다.

입출력 예 #2

  • "apple"은 몇 번을 밀어도 "elppa"가 될 수 없습니다.

입출력 예 #3

  • "atat"는 오른쪽으로 한 칸, 세 칸을 밀면 "tata"가 되므로 최소 횟수인 1을 반환합니다.

입출력 예 #4

  • "abc"는 밀지 않아도 "abc"이므로 0을 반환합니다.

🧞 풀이

function solution(A, B) {
    let cnt_l = 0;
    let cnt_r = 0;
    
    let a = A.split("");
    let b = B.split("");    
    let c = A.split("");
    let d = B.split("");

    // while (a.join("") != b.join("")) {
    //     if (cnt_l === a.length) {
    //         return -1
    //     }
    //     a.push(a.shift());
    //     cnt_l += 1;
    // }
    while (c.join("") != d.join("")) {
        if (cnt_r === c.length) {
            return -1
        }
        c.unshift(c.pop());
        cnt_r += 1;
    }
    return cnt_r;
}

🌠 문제

1부터 13까지의 수에서, 1은 1, 10, 11, 12, 13 이렇게 총 6번 등장합니다. 정수 i, j, k가 매개변수로 주어질 때, i부터 j까지 k가 몇 번 등장하는지 return 하도록 solution 함수를 완성해주세요.

🌠 제한사항

  • 1 ≤ i < j ≤ 100,000
  • 0 ≤ k ≤ 9

🌠 입출력 예

i j k result
1 13 1 6
10 50 5 5
3 10 2 0

🌠 입출력 예 설명

입출력 예 #1

  • 본문과 동일합니다.

입출력 예 #2

  • 10부터 50까지 5는 15, 25, 35, 45, 50 총 5번 등장합니다. 따라서 5를 return 합니다.

입출력 예 #3

  • 3부터 10까지 2는 한 번도 등장하지 않으므로 0을 return 합니다.

🧞 풀이

function solution(i, j, k) {
    let answer = 0;
    let array = [];
    for (let n = i; n <= j; n ++) {
        array.push(n.toString().split("").map(Number));
    }
    while (array.length != 0) {
        let tmp = array.shift();
        for (e in tmp) {
            if (tmp[e] === k) {
                answer += 1;
            }
        }
    }
    return answer;
}

+ Recent posts