알고리즘 공부 - Day01

설하나·2022년 10월 5일
0

알고리즘

목록 보기
1/22
post-thumbnail

부트캠프도 끝나고 풀어지지 않게 알고리즘 문제를 풀고, 공부를 하면서 내가 사용했던 메소드들을 잊지 않기위해, 풀어지지 않기 위해서 블로그에 공부한 기록을 남기기로 하였다.

오늘은 그 기록의 첫 단추이다.

🖥 프로그래머스 🖥

1. 나머지가 1이 되는 수 찾기

해당 문제는 자연수 n이 매개변수로 주어지고, n을 x로 나눈 나머지가 1이 되도록 하는 가장 작은 자연수 x를 return 하도록 solution 함수를 완성하는 문제였다.

나의 풀이는 아래와 같다.

function solution(n) {
    var answer = 0;
    for(let i = n;i>0;i--){
        if(n%i === 1){
            answer = i
        }
    }
    return answer;
}

2. 약수의 개수와 덧셈

해당문제는 두 정수 left와 right가 매개변수로 주어지고 left부터 right까지의 모든 수들 중에서, 약수의 개수가 짝수인 수는 더하고, 약수의 개수가 홀수인 수는 뺀 수를 return 해야하는 문제였다.

나의 풀이는 아래와 같다.

function solution(left, right) {
    var answer = 0;
    for(let i = 0;i+left<=right;i++){
        const num = left+i
        let count = 0
        for(let j=0;j<=num;j++){
            if(num%j===0) count++
        }
        if(count%2===0)answer+=num
        else answer-=num
    }
    return answer;
}

3. 수박수박수박수박수박수?

해당문제는 길이가 n이고, "수박수박수박수...."와 같은 패턴을 유지하는 문자열을 리턴하는 함수, solution을 완성하는 문제였다.

나의풀이는 아래와 같다.

function solution(n) {
    var answer = '';
    for(let i = 0;i<n;i++){
        if(i%2===0) answer+="수"
        else answer+="박"
    }
    return answer;
}

4. 부족한 금액 계산하기

해당문제는 놀이공원 기구를 타는데 중복해서 탈 경우 탄 횟수만큼 금액이 늘어나는 문제였다. 문제에 대해 자세한 내용은 아래에 기재하였다.

새로 생긴 놀이기구는 인기가 매우 많아 줄이 끊이질 않습니다. 이 놀이기구의 원래 이용료는 price원 인데, 놀이기구를 N 번 째 이용한다면 원래 이용료의 N배를 받기로 하였습니다. 즉, 처음 이용료가 100이었다면 2번째에는 200, 3번째에는 300으로 요금이 인상됩니다.
놀이기구를 count번 타게 되면 현재 자신이 가지고 있는 금액에서 얼마가 모자라는지를 return 하도록 solution 함수를 완성하세요.
단, 금액이 부족하지 않으면 0을 return 하세요.

나의풀이는 아래와 같다.

function solution(price, money, count) {
    var total = 0
    for(let i = 1;i<count+1;i++){
        total+=price*i
    }
    //금액이 부족하지 않은경우에는 0을 리턴하야하기 때문에 삼항연산자를 사용했다.
    return total-money<=0 ? 0 : total-money;
}
profile
Backend

0개의 댓글