如何计算Rust中的21阶乘? [英] How to calculate 21 factorial in Rust?

查看:137
本文介绍了如何计算Rust中的21阶乘?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我需要在我的项目中计算21阶乘.

I need to calculate 21 factorial in my project.

fn factorial(num: u64) -> u64 {
    match num {
        0 => 1,
        1 => 1,
        _ => factorial(num - 1) * num,
    }
}

fn main() {
    let x = factorial(21);
    println!("The value of 21 factorial is {} ", x);
}

运行此代码时,出现错误:

When running this code, I get an error:

thread 'main' panicked at 'attempt to multiply with overflow', src\main.rs:5:18

推荐答案

u64 不能容纳21个!(介于2 ^ 65和2 ^ 66之间),但是 u128 可以.

A u64 can’t hold 21! (it’s between 2^65 and 2^66), but a u128 can.

这篇关于如何计算Rust中的21阶乘?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆