자연수 n이 매개변수로 주어집니다. n을 x로 나눈 나머지가 1이 되도록 하는 가장 작은 자연수 x를 return 하도록 solution 함수를 완성해주세요. 답이 항상 존재함은 증명될 수 있습니다.
3 ≤ n ≤ 1,000,000
n result
10 3
12 11
10을 3으로 나눈 나머지가 1이고, 3보다 작은 자연수 중에서 문제의 조건을 만족하는 수가 없으므로, 3을 return 해야 합니다.
12를 11로 나눈 나머지가 1이고, 11보다 작은 자연수 중에서 문제의 조건을 만족하는 수가 없으므로, 11을 return 해야 합니다.
function solution(n) {
for(let i=2; i<n; i++){
if(n%i ===1){
return i
}else{
continue;
}
}
}
function solution(n) {
for(let i=2; i<n; i++){
if(n%i ===1)
return i
}
}
1)
function solution(n, x = 1) {
while (x++) {
if (n % x === 1) {
return x;
}
}
}
2)
function solution(n, x = 0) {
return n % x === 1 ? x : solution(n, x + 1);
// 테스트 한개가 런타임 에러가 나온다. }
다른 사람 풀이 1) 에서 의문점,,,
x=0 으로 설정하면 n에 값을 넣었을 때 undefined가 나온다.
function solution(n, x=0) {
while(x++){
if(n%x ===1){
return x
}
}
}
//solution(5)
//undefined
function solution(n, x=1) {
while(x++){
if(n%x ===1){
return x
}
}
}
solution(5)
2
function solution(n, x=2) {
while(x++){
if(n%x ===1){
return x
}
}
}
solution(5)
4