부트캠프도 끝나고 풀어지지 않게 알고리즘 문제를 풀고, 공부를 하면서 내가 사용했던 메소드들을 잊지 않기위해, 풀어지지 않기 위해서 블로그에 공부한 기록을 남기기로 하였다.
오늘은 그 기록의 첫 단추이다.
해당 문제는 자연수 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;
}
해당문제는 두 정수 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;
}
해당문제는 길이가 n이고, "수박수박수박수...."와 같은 패턴을 유지하는 문자열을 리턴하는 함수, solution을 완성하는 문제였다.
나의풀이는 아래와 같다.
function solution(n) {
var answer = '';
for(let i = 0;i<n;i++){
if(i%2===0) answer+="수"
else answer+="박"
}
return answer;
}
해당문제는 놀이공원 기구를 타는데 중복해서 탈 경우 탄 횟수만큼 금액이 늘어나는 문제였다. 문제에 대해 자세한 내용은 아래에 기재하였다.
새로 생긴 놀이기구는 인기가 매우 많아 줄이 끊이질 않습니다. 이 놀이기구의 원래 이용료는 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;
}