蓝桥杯2023年第十四届省赛真题-阶乘求和
一、题目
【问题描述】
令 S = 1 ! + 2 ! + 3 ! + . . . + 202320232023 ! S = 1! + 2! + 3! + ... + 202320232023!S=1!+2!+3!+...+202320232023!,求 S SS 的末尾 9 位数字。 提示:答案首位不为 0。
【答案提交】
这是一道结果填空的题,你只需要算出结果后提交即可。本题的结果为一 个整数,在提交答案时只填写这个整数,填写多余的内容将无法得分
二、思路
我自己想的时候是直接去计算1~202320232023的阶乘,可是202320232023超过了int的范围,也超过了long的范围,于是查看了答案,目前有两种思路:
1.法一
我们可以看到从39的阶乘之后后9位的阶乘都是0,(这也是题目中为啥让我们算末尾9位数了,相当于不用加40,41,42...等的阶乘),转化为,求1~39的阶乘和。
| 10! | 3628800 |
| 20! | 2432902008176640000 |
| 30! | 265252859812191058636308 480000000 |
| ... | |
| 39! | 20397882081197443358640281739902897356 800000000 |
| 40! | 815915283247897734345611269596115894272 000000000 |
| 41! | 33452526613163807108170062053440751665152 000000000 |
| 42! | 1405006117752879898543142606244511569936384 000000000 |
| 43! | 60415263063373835637355132068513997507264512 000000000 |
| 44! | 2658271574788448768043625811014615890319638528 000000000 |
但我们也不是单纯的算1~39的阶乘,因为计算的过程中数将会非常的大,我们在每次算到某个数的阶乘时把它对 模运算9 得到后9位数字 ,同时,把这个数加到阶乘和 里的时候也要 模9,最终直接输出即可。
package lan2023;public class A阶乘求和 {public static void main(String[] args) {long s = 0;long j = 1;for(int i = 1; i <= 39; i++) {j = j * i % (long)1e9; s = s + j;s = s % (long)1e9;}System.out.println(s);}
}
运行结果: 420940313
二、法二:
因为这个题涉及到阶乘 甚至要 求和,我们此时可以使用BigInteger类 ,
创建BigInteger类:
以字符串的形式:BigInteger sum = new BigInteger("0");
以long型数据:BigInteger sum = BigInteger.valueOf(0);
方法:
加 a.add(b)
减 a.subtract(b)
乘 a.multiply(b)
除 a.divide(b)
比较大小 a.compareTo(b)
package lan2023;import java.math.BigInteger;public class A阶乘求和 {public static void main(String[] args) { BigInteger sum = BigInteger.valueOf(0);BigInteger j = BigInteger.valueOf(1);for(int i = 1; i <= 39; i++) {j = j.multiply(BigInteger.valueOf(i));sum = sum.add(j);}System.out.println(sum);//最后记得取后9位}
}
使用 大数(BigInteger) 时也没什么不同,就是不管啥时候要使用他的方法,运算的时候 两个数都要是大数 注意: 将一个整数a转化位大数 BigInteger.valueOf(a)
相关文章:
蓝桥杯2023年第十四届省赛真题-阶乘求和
一、题目 【问题描述】 令 S 1 ! 2 ! 3 ! . . . 202320232023 ! S 1! 2! 3! ... 202320232023!S1!2!3!...202320232023!,求 S SS 的末尾 9 位数字。 提示:答案首位不为 0。 【答案提交】 这是一道结果填空的题,你只需要算出结果后…...
多租户平台前端存储结构的选择
下图来源于cookie、localStorage 和 sessionStorage的区别及应用实例 既然localstorage无有效期,关闭浏览器还存在,那么用来存储用户的身份信息并不是太合适,先看一下B站中localstorage都存在了啥,原来把我搜索的记录都存在了下来…...
C++11 新特性:常量表达式 constexpr(下)
接上篇文章,继续说说常量表达式 constexpr 在模板编程中的使用场景。 constexpr 用于模板编程 在模板编程中,constexpr 的应用非常广泛,主要是因为它能够在编译时进行计算,这对于模板元编程、编译时断言、模板特化选择等场合尤为…...
大数据开发--02.环境准备
一.准备三台linux虚拟机 1.分别取名node1,node2,node3 2.配置静态ip 这里以node1为例,配置静态ip地址,其他node2.node3一样 配置完成之后别忘记 systemctl restart network 3.在各自的/etc/hosts文件中编辑三个Ip地址 三台都要配置, 4.然…...
选择word中的表格VBA
打开开发工具 选择Visual Basic插入代码 Sub 选择word中的表格() Dim t As Table an MsgBox("即将选择选区内所有表格,若无选区,则选择全文表格。", vbYesNo, "提示") If an - 6 Then Exit Sub Set rg IIf(Selection.Type wdSel…...
开放签开源电子签章白皮书-简版
开放签开源电子签章白皮书-简版 一、摘要: 开放签电子签章团队源自于电子合同SaaS公司,立志于通过开源、开放的模式,结合团队十多年的行业经验,将电子签章产品更简单、更低门槛的推广到各行各业中。让电子签章应用更简单&#x…...
uniapp、vue2.6、H5,利用腾讯TRTC,快速跑通1v1视频功能
多人视频聊天室搭建,官网已有相关demo和案例,需要快速搭建多人聊天室直接进入以下网站: 实时音视频 Web & H5 (Vue2/Vue3)-视频通话(含 UI)-文档中心-腾讯云说明:https://cloud.tencent.com/document/…...
Spring Data访问Elasticsearch----查询方法
Spring Data访问Elasticsearch----查询方法 一、查询lookup策略1.1 声明的查询 二、创建查询三、方法返回类型四、使用Query注解 一、查询lookup策略 Elasticsearch模块支持所有基本的查询构建功能,如字符串查询、native搜索查询、基于条件的查询和从方法名派生的查…...
PyTorch 深度学习(GPT 重译)(四)
第二部分:从现实世界的图像中学习:肺癌的早期检测 第 2 部分的结构与第 1 部分不同;它几乎是一本书中的一本书。我们将以几章的篇幅深入探讨一个单一用例,从第 1 部分学到的基本构建模块开始,构建一个比我们迄今为止看…...
视频无水印批量下载软件|抖音视频提取工具
视频无水印批量下载软件 在当今社交媒体充斥着大量优质视频内容的时代,很多用户都希望能够轻松下载自己喜爱的视频进行收藏或分享。为了满足用户的需求,我们特别推出了一款专业的视频无水印批量下载软件,让您可以方便快捷地获取喜爱的视频内容…...
【linux】环境基础|开发工具|gcc|yum|vim|gdb|make|git
目录 编辑 Linux 软件包管理器 yum 软件包: 操作: 拓展:lrzsz简介 Linux开发工具 Linux编辑器-vim使用 vim 的基本概念 命令模式 插入模式 底行模式 vim 命令模式的操作指令 vim 底行模式的操作命令 Linux编译器-gcc/g使用 功能 格…...
小程序中实现轮播图左向堆叠
1、效果图: 轮播图左向堆叠 2、封装的组件: my-swiper.wxml <view><view class"tower-swiper" bindtouchend"TowerEnd"><view class"tower-item" wx:for"{{swiperList}}" wx:key"index&q…...
零基础入门数据挖掘系列之「建模调参」
摘要:对于数据挖掘项目,本文将学习如何建模调参?从简单的模型开始,如何去建立一个模型;如何进行交叉验证;如何调节参数优化等。 建模调参:特征工程也好,数据清洗也罢,都是…...
如何在Mac中删除照片?这里有详细步骤
前言 本文介绍如何从Mac中删除照片,以释放硬盘空间或更好地组织文件和文件夹。 如何使用废纸篓删除Mac上的图片 在Mac上删除图片的最简单方法之一是使用废纸篓功能。学习只需几秒钟。下面是如何删除单个图片以及如何在Mac上删除多个图片,以及一些关键和有用的提示,以使该…...
Qt笔记 事件处理_鼠标事件
什么是事件? 点击鼠标左键,双击鼠标左键,鼠标来回移动,按下键盘按钮,这些都是事件。 那么事件的响应机制是什么样的呢? 首先main函数中有一个QApplication,其作用是创建一个应用程序对象&…...
【Vue】三、使用ElementUI实现图片上传
目录 一、前端代码实现 二、后端代码实现 三、调试效果实现 一、前端代码实现 废话不多说直接上代码 <el-form-item prop"image" label"上传图片" v-model"form.image"><el-upload:action"http://localhost:8…...
ffmpeg的ffprobe.exe查询修改视频信息
# 查询视频信息 ffprobe -i 1.mp4Input #0, mov,mp4,m4a,3gp,3g2,mj2, from video.mp4:Metadata:major_brand : isomminor_version : 512compatible_brands: isomiso2avc1mp41encoder : Lavf58.20.100comment : 123654Duration: 00:00:15.21, start: 0.0…...
Windows 2019服务器上安装NFS服务器
提供NFS服务服务器: Windows 2019服务器上安装NFS服务器资源管理器 创建目录比如D:\nfshare, 鼠标邮件菜单 点击 属性,进行NFS共享 使用NFS服务的客户端: 另外一台Windows服务器,需要安装NFS客户端 具体操作:Window…...
元素定位之xpath和css
元素定位 xpath绝对路径相对路径案例xpath策略(路径)案例xpath策略(层级、扩展)属性层级与属性层级与属性拓展层级与属性综合 csscss选择器(id、类、标签、属性)id选择器类选择器标签选择器属性选择器案例-…...
JavaScript 什么是纯函数,有哪些常见的纯函数
什么是纯函数 纯函数是指那些不依赖于外部状态,也不改变外部状态的函数。在JavaScript中,纯函数的返回值仅由其输入参数决定,而且执行纯函数不会产生副作用,比如修改全局变量或修改传入的参数。 常见的纯函数 JavaScript中一些常…...
树莓派4B网络启动后,如何用NFS挂载实现多台Pi共享一个系统镜像?
树莓派4B网络启动进阶:NFS共享系统镜像的多设备部署方案 当实验室里摆放着二十台树莓派,每台都需要相同的开发环境时,传统SD卡烧录方式立刻暴露出效率短板。想象一下:系统升级需要逐台插拔卡片,配置变更要重复操作二十…...
如何快速掌握Comics Downloader:漫画离线阅读的终极解决方案
如何快速掌握Comics Downloader:漫画离线阅读的终极解决方案 【免费下载链接】comics-downloader tool to download comics and manga in pdf/epub/cbr/cbz from a website 项目地址: https://gitcode.com/gh_mirrors/co/comics-downloader 还在为在线漫画加…...
SDF文件在时序仿真中的关键作用与反标实践
1. SDF文件:数字芯片时序仿真的"延时字典" 第一次接触SDF文件时,我把它想象成一本记录所有电路延时信息的"字典"。这本字典详细标注了信号在芯片内部传输时可能遇到的各类延时情况,就像快递员送包裹时遇到的交通状况记录…...
从流水灯到通信协议:深入浅出聊聊移位寄存器在单片机与嵌入式里的那些实用场景
从流水灯到通信协议:深入浅出聊聊移位寄存器在单片机与嵌入式里的那些实用场景 在嵌入式开发的世界里,我们每天都在与各种外设打交道——点亮LED、读取按键、通过串口发送数据。这些看似简单的操作背后,其实隐藏着一套精妙的数字逻辑体系。移…...
从‘黑盒’到‘白盒’:深入理解sklearn StandardScaler的inverse_transform,让你的模型预测结果‘看得见’也‘回得去’
从‘黑盒’到‘白盒’:深入理解sklearn StandardScaler的inverse_transform,让你的模型预测结果‘看得见’也‘回得去’ 在机器学习项目中,数据标准化是预处理阶段不可或缺的一环。然而,许多从业者往往只关注如何将数据转换为标准…...
JMeter实战指南:从零构建高效接口测试框架
1. JMeter环境搭建与基础配置 第一次接触JMeter时,我也被它复杂的界面吓到过。但实际用下来发现,只要环境配置正确,这个工具用起来比Postman还顺手。我们先从最基础的环境搭建说起,这里我会分享几个容易踩坑的细节。 JDK安装是第一…...
别再手动调参了!用YOLOv5的K-means+遗传算法,为你的数据集定制专属Anchors
突破目标检测瓶颈:YOLOv5 Anchors优化实战指南 在目标检测任务中,Anchors的质量直接影响模型性能。传统手工设计Anchors的方式早已被自动化方法取代,但大多数开发者仍停留在使用默认Anchors的阶段。本文将揭示如何通过K-means与遗传算法的组合…...
告别大Batch和负样本:手把手复现SimSiam自监督训练(PyTorch版)
从零实现SimSiam自监督学习:PyTorch实战与调优指南 引言:为什么需要关注SimSiam? 2021年CVPR最佳论文提名的SimSiam,以其简洁优雅的设计在自监督学习领域掀起波澜。不同于传统对比学习需要海量负样本或超大batch size,…...
UE建模工具实战指南:从基础操作到高效技巧
1. UE建模工具入门:认识基础操作 第一次打开UE建模工具时,很多人会被密密麻麻的按钮吓到。别担心,我们先从最常用的几个功能开始。就像学做菜要先认识锅碗瓢盆一样,掌握这些基础工具,你就能完成80%的建模工作了。 **晶…...
特征融合实战:从Concat/Add到Attention的演进与选型
1. 特征融合的基础概念与核心价值 第一次接触特征融合这个概念时,我正为一个目标检测项目焦头烂额。当时模型对小物体检测效果特别差,前辈建议我试试特征金字塔融合。那是我第一次意识到,原来神经网络中的特征还能像调鸡尾酒一样混合搭配。简…...
