返回介绍

solution / 2800-2899 / 2803.Factorial Generator / README

发布于 2024-06-17 01:02:59 字数 1562 浏览 0 评论 0 收藏 0

2803. 阶乘生成器

English Version

题目描述

编写一个生成器函数,该函数以一个整数 n 作为参数,并返回一个生成器对象,该生成器对象可以生成 阶乘序列

阶乘序列 的定义如下:n! = n * (n-1) * (n-2) * ... * 2 * 1 。

0 的阶乘被定义为 1。

 

示例 1:

输入:n = 5
输出:[1,2,6,24,120]
解释:
const gen = factorial(5)
gen.next().value // 1
gen.next().value // 2
gen.next().value // 6
gen.next().value // 24
gen.next().value // 120

示例 2:

输入:n = 2
输出:[1,2]
解释:
const gen = factorial(2) 
gen.next().value // 1 
gen.next().value // 2 

示例 3:

输入:n = 0
输出:[1]
解释:
const gen = factorial(0) 
gen.next().value // 1 

 

提示:

  • 0 <= n <= 18

解法

方法一

function* factorial(n: number): Generator<number> {
  if (n === 0) {
    yield 1;
  }
  let ans = 1;
  for (let i = 1; i <= n; ++i) {
    ans *= i;
    yield ans;
  }
}

/**
 * const gen = factorial(2);
 * gen.next().value; // 1
 * gen.next().value; // 2
 */

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文