怎么用非递归的方式求 n 的阶乘呢?不需要递归的,递归的我了谢谢
给定一个 n,求它的阶乘~
1条回答 默认 最新
关注 #include <stdio.h> int main() { int n, ans; while(scanf("%d", &n) != EOF) { ans = 1; // (1) while(n) { // (2) ans *= n; // (3) --n; // (4) } printf("%d\n", ans); } return 0; }
- $(1)$ 初始化结果
ans
为1; - $(2)$ 用一个
while
语句来执行循环,一直自减n
,直到n
减为零为止; - $(3)$ 将当前
n
的值累乘给ans
(循环完毕,ans
就是1
到n
的数的累乘的积); - $(4)$
--n
等价于n = n - 1
; - 这种方法,就是普通的枚举,正确性容易保证。
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 1无用- $(1)$ 初始化结果
悬赏问题
- ¥15 Attention is all you need 的代码运行
- ¥15 一个服务器已经有一个系统了如果用usb再装一个系统,原来的系统会被覆盖掉吗
- ¥15 使用esm_msa1_t12_100M_UR50S蛋白质语言模型进行零样本预测时,终端显示出了sequence handled的进度条,但是并不出结果就自动终止回到命令提示行了是怎么回事:
- ¥15 前置放大电路与功率放大电路相连放大倍数出现问题
- ¥30 关于<main>标签页面跳转的问题
- ¥80 部署运行web自动化项目
- ¥15 腾讯云如何建立同一个项目中物模型之间的联系
- ¥30 VMware 云桌面水印如何添加
- ¥15 用ns3仿真出5G核心网网元
- ¥15 matlab答疑 关于海上风电的爬坡事件检测