牛客题解 | 求整数的阶乘

news/2025/3/10 10:27:22/文章来源:https://www.cnblogs.com/wc529065/p/18762019

题目

题目链接

题解:

题目难度:中等难度

难点:

1.由于数据太大无法通过整数类型表示,因此用字符串存储结果
2.对于每个字符串从尾部开始进行简单的乘法,在其中考虑进位

知识点:大数相乘

思路:

1.构造multiply(int x, int res[], int res_size)函数,数组res存储被乘数,res_size为被乘数的位数,x为乘数,该函数将两者乘积结果放入数组res(res重新赋值为两者的乘积),该函数返回数组乘积结果的长度。比如10!=3628800已经存储到数组res中,此时res_size=7,计算11!=10! * 11过程如下:

步骤一:

从数组res下标0处开始,依次乘上11,如res[i]11,因为十进制数,考虑向前进位,所以此时res[i]=(res[i]11)%10,向前进位carry = (res[i]*11)/10。按这种方式从下标0计算到下标res_size-1。

步骤二:

需要计算最高为res[res_size-1]所产生的进位。此时产生的进位carry=(res[res_size-1]*11)/10。此时使用while循环判断carry时几位数,把该数从低位开始依次存入res[res_size++]中。
那么调用multiply( 11, int res[], 7)

图片说明

2.计算n!相当于计算1!2=2!,2!3=3!,3!*4=4!,依次类推下去。因此,利用for循环,i从1到n,在其中依次调用multiply(i, res[], res_size),最终n!的结果保存在数组res中,从高位到低位依次输出即可。

#include <iostream>
using namespace std;
// 数组e799bee5baa6e58685e5aeb931333361326235乘法, res_size: 表示有多少位, 返回结果的位数
int multiply(int x, int res[], int res_size) {int carry = 0;  // 进位for (int i=0; i<res_size; i++) { int prod="res[i]" * x="2;" + carry; res[i]="prod" % 10; carry="carry/10;" } while (carry!="0)" res[res_size]="carry%10;" res_size++; return res_size; void factorial(int n) res[36000]; 10000! 位数不超过36000 初始化 res[0]="1;" res_size="multiply(x," 表示有多少位 计算 n! for (int x<="n;" x++) res, res_size); i>=0; i--) {cout&lt;<res[i]; } int main() { n; cin>&gt;n;factorial(n);
}

</res[i];></res_size;>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/896704.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

OP13常见问题

1.直振与切料口的对中 问题:对中不良,导致送料不到位,对光传感器检测不到产品,报警直振缺料。解决方法: 先检查气缸自带的行程调节器有无松动,如果没有松动,通过微调振动盘机构的位置及底脚高度,实现切料口上下左右的对中。2.机器人夹爪气缸磁开线路 1.M8接头长期晃动,…

Android Studio 2022下载与安装

1、安装包 扫描下方二维码关注「软知社」,后台回复【066】三位数字即可免费获取分享链接,无广告拒绝套路; 2、安装教程解压下载安装包,双击Setup.exe安装,弹窗安装对话框点击下一步默认,点击下一步选择安装目录,建议选择C盘之外,点击下一步点击安装安装完成,点击下一…

Adobe Photoshop 2025下载与安装

‌Photoshop 2025的安装环境要求主要包括操作系统、处理器、内存、显卡、显示器分辨率和硬盘空间等方面的具体要求。‌ 操作系统要求‌Windows‌:支持Windows 10(版本21H2)或更高版本,不支持Windows的长期服务版(LTSC)。处理器要求‌Windows‌:支持64位的多核Intel或AMD…

Capture one 2023下载与安装教程

1、安装包 扫描下方二维码关注「软知社」,后台回复【061】三位数字即可免费获取分享链接,无广告拒绝套路; 2、安装教程(建议关闭杀毒软件和系统防护)解压下载安装包,双击软件安装,弹窗安装对话框选择中文,点击确定选择‘我同意。’ 点击下一步选择安装目录,建议C盘之外…

S3FT选择性自监督微调:通过智能选择训练样本提升大模型整体表现

选择性自我监督微调(Selective Self-to-Supervised Fine-Tuning,S3FT)是一种创新的大语言模型微调方法,该方法通过部署专门的语义等价性判断器来识别训练集中模型自身生成的正确响应。在微调过程中,S3FT策略性地结合这些正确响应与剩余样本的标准答案(或其释义版本)来优…

20242935 2024-2025-2 《网络攻防实践》第二周作业

20242935 2024-2025-2 《网络攻防实践》第二周作业 网络信息收集技术 一、实验要求 (1)从www.besti.edu.cn、baidu.com、sina.com.cn中选择一个DNS域名进行查询,获取如下信息:DNS注册人及联系方式 该域名对应IP地址 IP地址注册人及联系方式 IP地址所在国家、城市和具体地理…

Xmanager 8下载与安装教程

1、安装包 扫描下方二维码关注「软知社」,后台回复【059】三位数字即可免费获取分享链接,无广告拒绝套路; 2、安装教程(建议关闭杀毒软件与本地防护设置)双击Xmanager-8.0.0055r.exe安装,弹窗安装对话框点击下一步选择‘我接受。。’,点击下一步选择安装目录D盘,点击下一…

Xftp 8软件下载与安装教程

Xftp 8中文版是一款十分强大、传输快速的FTP文件传输工具,它拥有着十分庞大的用户群体,其凭借着简单的界面、便捷的操作以及强大的功能,深受广大用户的好评与喜爱,当然它也是许许多多专业人士的必备工具之一。 由于Xftp 8是基于MS windows平台的STP和FTP传输工具,所以它不…

HarmonyOS SDK让小红书鸿蒙用户尽享原生相机的拍摄之美

小红书是深受年轻人喜爱的生活社交类社区平台,越来越多的人在小红书上分享旅行、日常、心情。近日,不少使用鸿蒙原生版小红书的细心用户已经发现,直接使用小红书拍摄照片与自己使用原相机拍摄有一样清晰美观的呈现效果。不仅如此,小红书现已支持用户直接从图库中上传动态照…

Xshell 8软件下载与安装教程

1、安装包 扫描下方二维码关注「软知社」,后台回复【057】三位数字即可免费获取分享链接,无广告拒绝套路; 2、安装教程(建议关闭杀毒软件与本地防护设置)双击Xshell-8.0.0055r.exe安装,弹窗安装对话框点击下一步选择‘我接受。。’,点击下一步选择安装目录D盘,点击下一步…

(附体验地址)大模型知识引擎:AI 助手能否助力销售技能提升?

体验地址:https://lke.cloud.tencent.com/webim_exp/#/chat/FAIMcM 腾讯云的大模型知识引擎本身定位于为企业客户及合作伙伴提供服务,因此我在探索如何最佳利用其现有功能与特点时,专注于实际应用场景的挖掘。为此,今天我搭建出了一个卖车销售话术练习助手,旨在帮助销售人…

Hyper V高级用法:优化虚拟机性能策略

在利用Hyper-V进行虚拟化部署时,优化虚拟机性能是至关重要的,这涉及到多个方面的策略和配置。以下是一些高级用法和优化策略,旨在提升虚拟机的整体性能和资源利用率:一、硬件配置优化 启用硬件虚拟化: 确保主机的CPU支持硬件虚拟化技术(如Intel VT-x或AMD-V),并在BIOS/…