저장을 습관화

프로그래머스 LV.0 홀짝에 따라 다른 값 반환하기 본문

코딩 테스트/프로그래머스 - 자바스크립트

프로그래머스 LV.0 홀짝에 따라 다른 값 반환하기

ctrs 2023. 9. 13. 20:29

프로그래머스 LV.0 홀짝에 따라 다른 값 반환하기

https://school.programmers.co.kr/learn/courses/30/lessons/181935

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

 

1. 문제 명

홀짝에 따라 다른 값 반환하기


2. 문제 설명

양의 정수 n이 매개변수로 주어질 때, n이 홀수라면 n 이하의 홀수인 모든 양의 정수의 합을 return 하고 n이 짝수라면 n 이하의 짝수인 모든 양의 정수의 제곱의 합을 return 하는 solution 함수를 작성해 주세요.


3. 제한 사항

- 1 ≤ n ≤ 100


4. 예시

n result
7 16
10 220


5. 기본 제공 코드

function solution(n) {
    var answer = 0;
    return answer;
}


6. 제출한 내 답

const solution = (n) => {
  let answer = 0;

  console.log("테스트 1");

  const calOdd = (n) => {
    for (i = 1; i <= n; i += 2) {
      answer += i;
      console.log(answer);
    }
    return answer;
  };


  const calEven = (n) => {
    for (i = 2; i <= n; i += 2) {
      answer += i * i;
    }
    return answer;
  };

  return n % 2 ? calOdd(n) : calEven(n);
};

 

6-2. VSC에 작성한 내용

const solution = (n) => {
  let answer = 0;

  console.log("테스트 1");

  const calOdd = (n) => {
    console.log("테스트 4");
    for (i = 1; i <= n; i += 2) {
      answer += i;
      console.log(answer);
    }
    console.log("테스트 5");
    return answer;
  };

  console.log("테스트 2");

  const calEven = (n) => {
    console.log("테스트 6");
    for (i = 2; i <= n; i += 2) {
      answer += i * i;
    }
    console.log("테스트 7");
    return answer;
  };

  console.log("테스트 3");

  return n % 2 ? calOdd(n) : calEven(n);
};

// 테스트
console.log(solution(7));
console.log(solution(10));

// console.log(solution());


7. 특이사항

없음


8. 다른 사람이 작성한 답

8-1.

function solution(n) {
    if(n%2===1)
      return  (n+1)/2*((n + 1)/2) ;
    else
      return   n*(n+1)*(n+2)/6;
}

 

8-2.

function solution(n) {
    var answer = 0;

    if(n%2==0){
        for(let i=1; i<=n; i++){
            if(i%2==0){
                answer += i*i;
            }
        }
    }
    else{
        for(let i=1; i<=n; i++){
            if(i%2==1){
                answer += i;
            }
        }
    }

    return answer;
}