> 웹 프론트엔드 > 프런트엔드 Q&A > 자바스크립트 윤년 찾기

자바스크립트 윤년 찾기

王林
풀어 주다: 2023-05-09 14:34:06
원래의
1167명이 탐색했습니다.

윤년은 그레고리력에서 윤일(예: 2월 29일)이 있는 해를 의미합니다. 그레고리력의 법칙에 따르면 4년마다 윤년이 있지만 100년마다 윤년이 없고 400년마다 윤년이 또 있습니다. JavaScript에서는 다음 함수를 사용하여 해당 연도가 윤년인지 확인할 수 있습니다.

function isLeapYear(year) {
  return (year % 4 === 0 && year % 100 !== 0) || (year % 400 === 0);
}
로그인 후 복사

위 코드에서는 먼저 해당 연도가 4로 나눌 수 있는지 여부를 확인합니다. 100으로 나눌 수 있고 나눌 수 없는 경우 또는 400으로 나누어 떨어지는 해는 올해가 윤년이라는 뜻이다. 조건이 충족되지 않으면 윤년이 아니다.

이 기능의 구현은 비교적 간단하지만 주의해야 할 몇 가지 사항이 있습니다. 예를 들어 함수 호출 시 전달된 매개변수가 정수형이 아닌 경우 계산 과정에 문제가 있을 수 있다. 이러한 상황을 피하기 위해 함수 시작 부분에 매개변수 유형을 확인하는 코드를 추가할 수 있습니다.

function isLeapYear(year) {
  if (typeof year !== 'number' || year % 1 !== 0) {
    throw new TypeError('Year must be an integer');
  }

  return (year % 4 === 0 && year % 100 !== 0) || (year % 400 === 0);
}
로그인 후 복사

위 코드에서는 시작 부분에 매개변수 유형 확인 로직을 추가했습니다. 전달된 매개변수가 정수 유형이 아닌 경우 유형 오류 예외가 발생합니다. 이렇게 하면 코드의 견고성이 향상되고 예측할 수 없는 오류를 방지할 수 있습니다.

매개변수 유형을 확인하는 것 외에도 함수에 대한 몇 가지 추가 최적화를 수행할 수도 있습니다. 예를 들어, 같은 연도에 대한 반복 계산을 피하기 위해 일부 캐싱 메커니즘을 추가할 수 있습니다. 이를 통해 컴퓨팅 리소스를 절약하고 기능 성능을 향상할 수 있습니다. 다음은 캐싱 메커니즘을 추가하는 샘플 코드입니다.

function createLeapYearChecker() {
  const cache = {};

  return function(year) {
    if (typeof year !== 'number' || year % 1 !== 0) {
      throw new TypeError('Year must be an integer');
    }

    if (year in cache) {
      return cache[year];
    }

    const isLeapYear = (year % 4 === 0 && year % 100 !== 0) || (year % 400 === 0);
    cache[year] = isLeapYear;
    return isLeapYear;
  };
}

const isLeapYear = createLeapYearChecker();
console.log(isLeapYear(2020)); // true
console.log(isLeapYear(2021)); // false
console.log(isLeapYear(2022)); // false
console.log(isLeapYear(2023)); // false
console.log(isLeapYear(2024)); // true
console.log(isLeapYear(2020)); // true - result is retrieved from cache
로그인 후 복사

위 코드에서는 원래 함수를 팩토리 함수로 변경했습니다. 이 팩토리 함수는 계산 결과를 저장하기 위한 캐시 개체가 포함된 내부 함수를 반환합니다. 이 내부 함수는 연도 매개변수를 받을 수 있으며 먼저 올해의 계산 결과가 이미 캐시에 있는지 확인합니다. 존재하는 경우 캐시에 저장된 결과를 직접 반환하고, 그렇지 않은 경우 다시 계산하여 결과를 캐시에 저장합니다.

캐싱 메커니즘을 추가하면 함수를 호출할 때 같은 연도의 반복 계산을 피할 수 있어 함수의 실행 효율성이 향상됩니다. 동시에 캐싱 메커니즘은 외부 코드에 투명하므로 사용자는 캐시를 관리하기 위해 추가 코드가 필요하지 않습니다.

간단히 말하면 자바스크립트에서 윤년을 찾는 문제는 아주 기본적인 문제이지만, 실제 코딩에서는 주의가 필요한 부분이 있을 수 있습니다. 기본적인 판단 논리 외에도 캐싱 메커니즘과 기타 방법을 추가하여 코드의 견고성과 실행 효율성을 향상시켜 기능을 최적화할 수도 있습니다.

위 내용은 자바스크립트 윤년 찾기의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿