题解 | #C.idol!!# 2023牛客暑期多校6
C.idol!!
数学
题目大意
正整数 n n n 的双阶乘 n ! ! n!! n!! 表示不超过 n n n 且与 n n n 有相同奇偶性的所有正整数乘积
求对于给定 n n n , ∏ i = 1 n i ! ! \prod\limits_{i=1}^n i!! i=1∏ni!! 的后缀 0 0 0 个数
解题思路
根据双阶乘的性质,可以得到: ( n − 1 ) ! ! × n ! ! = n ! (n-1)!!\times n!!=n! (n−1)!!×n!!=n!
因此对于给定的 n n n ,原式可化为:
∏ i = 1 n i ! ! = { ∏ i = 1 n 2 ( 2 i ) ! , n 为偶数 ∏ i = 1 n + 1 2 ( 2 i − 1 ) ! , n 为奇数 \prod\limits_{i=1}^n i!!=\begin{cases} \prod\limits_{i=1}^\frac{n}{2} (2i)! &,n为偶数 \\ \prod\limits_{i=1}^\frac{n+1}{2} (2i-1)! &,n为奇数 \end{cases} i=1∏ni!!=⎩ ⎨ ⎧i=1∏2n(2i)!i=1∏2n+1(2i−1)!,n为偶数,n为奇数
显而易见的,阶乘中因子 2 2 2 的个数一定多于因子 5 5 5 的个数,因此题目等价于求上式中因子 5 5 5 的个数//
考虑某单一阶乘 n ! n! n! 中所含因子 5 5 5 的个数。
可以发现,每个 5 5 5 的倍数项会提供 1 1 1 个因子 5 5 5 ,共有 ⌊ n 5 ⌋ \lfloor \dfrac{n}{5} \rfloor ⌊5n⌋ 项
除此之外每个 25 = 5 2 25=5^2 25=52 的倍数项会额外提供一个因子 5 5 5 ,共有 ⌊ n 5 2 ⌋ \lfloor \dfrac{n}{5^2} \rfloor ⌊52n⌋ 项
再除此之外每个 125 = 5 3 125=5^3 125=53 的倍数项会额外提供一个因子 5 5 5 ,共有 ⌊ n 5 3 ⌋ \lfloor \dfrac{n}{5^3} \rfloor ⌊53n⌋ 项……
因此对于单一阶乘 n ! n! n! ,其提供因子 5 5 5 的数量 c n t 5 = ∑ i = 1 N ⌊ n 5 i ⌋ ( 5 N > n ) cnt_5=\sum\limits_{i=1}^N \lfloor \dfrac{n}{5^i} \rfloor (5^N>n) cnt5=i=1∑N⌊5in⌋(5N>n)
接着考虑连乘积中因子 5 5 5 个数的总和。
a n s = { ∑ i = 1 n 2 ∑ j = 1 N ⌊ 2 i 5 j ⌋ = ∑ i = 1 N ∑ j = 1 n 2 ⌊ 2 j 5 i ⌋ , n 为偶数 ∑ i = 1 n + 1 2 ∑ j = 1 N ⌊ 2 i − 1 5 j ⌋ = ∑ i = 1 N ∑ j = 1 n + 1 2 ⌊ 2 j − 1 5 i ⌋ , n 为奇数 ans=\begin{cases} \sum\limits_{i=1}^\frac{n}{2} \sum\limits_{j=1}^N \lfloor \dfrac{2i}{5^j} \rfloor=\sum\limits_{i=1}^N \sum\limits_{j=1}^\frac{n}{2} \lfloor \dfrac{2j}{5^i} \rfloor &,n为偶数 \\ \sum\limits_{i=1}^\frac{n+1}{2} \sum\limits_{j=1}^N \lfloor \dfrac{2i-1}{5^j} \rfloor=\sum\limits_{i=1}^N \sum\limits_{j=1}^\frac{n+1}{2} \lfloor \dfrac{2j-1}{5^i} \rfloor &,n为奇数 \end{cases} \\ ans=⎩ ⎨ ⎧i=1∑2nj=1∑N⌊5j2i⌋=i=1∑Nj=1∑2n⌊5i2j⌋i=1∑2n+1j=1∑N⌊5j2i−1⌋=i=1∑Nj=1∑2n+1⌊5i2j−1⌋,n为偶数,n为奇数
对于某一 i i i ,发现不论 n n n 的奇偶, j = 1 j=1 j=1 开始的每 5 i 5^i 5i 项之和构成公差为 2 × 5 i 2\times5^i 2×5i 的等差数列//
例: i = 1 i=1 i=1 , n n n 为偶数且足够大时, ⌊ 2 j 5 i ⌋ \lfloor \dfrac{2j}{5^i} \rfloor ⌊5i2j⌋ 的前 15 15 15 项如下,其中每 5 5 5 项之和构成公差为 5 × 2 5\times 2 5×2 的等差数列: 0 , 0 , 1 , 1 , 2 ∣ ∣ 2 , 2 , 3 , 3 , 4 ∣ ∣ 4 , 4 , 5 , 5 , 6 … … 0,0,1,1,2||2,2,3,3,4||4,4,5,5,6…… 0,0,1,1,2∣∣2,2,3,3,4∣∣4,4,5,5,6……
经计算,对于某一 i i i ,等差数列的首项为
a 1 = { ⌊ 5 i 2 ⌋ + 2 , n 为偶数 ⌊ 5 i 2 ⌋ + 1 , n 为奇数 a_1=\begin{cases} \lfloor \dfrac{5^i}{2} \rfloor+2 &,n为偶数 \\ \lfloor \dfrac{5^i}{2} \rfloor+1 &,n为奇数 \end{cases} a1=⎩ ⎨ ⎧⌊25i⌋+2⌊25i⌋+1,n为偶数,n为奇数
完整的段用等差数列求和,非完整的段手算一下//
若此前完整段的数量记为 m m m ,则非完整段:
前 ⌊ 5 i 2 ⌋ \lfloor \dfrac{5^i}{2} \rfloor ⌊25i⌋ 项的值为 2 m 2m 2m ,
第 ⌊ 5 i 2 ⌋ + 1 \lfloor \dfrac{5^i}{2} \rfloor+1 ⌊25i⌋+1 至 $2\times\lfloor \dfrac{5^i}{2} \rfloor $ 项的值为 2 m + 1 2m+1 2m+1(手搓一下就知道了)
求和即可
令 N = ⌊ log 5 n ⌋ + 1 N=\lfloor \log_5n \rfloor+1 N=⌊log5n⌋+1 ,对 i ∈ [ 1 , N ] i\in[1,N] i∈[1,N] 遍历求和得到答案
由于答案数据极其庞大,超出了C++ %lld(64bits)的范围,因此需要使用更高位数的整数类型(如int128)//或者直接转战Python
时间复杂度
O ( log n ) O(\log n) O(logn)
参考代码
import math
# while 1:
n=int(input())
N=int(math.log(n,5)+1)
re=0
if n%2==0 :for i in range(1,N+1) :#print("i="+str(i))a1=(5**i)//2+2 #首项#print("a1="+str(a1))d=(5**i)*2 #公差#print("d="+str(d))m=(n//2)//(5**i) #完整段数#print("m="+str(m))re+=(2*a1+(m-1)*d)*m//2 #完整段等差数列求和#print("re1:" + str(re))re+=(n//2-m*(5**i))*2*m #最后一段余项求和#print("re2:" + str(re))#print("pl1=" + str((n//2-m*(5**i))*2*m))if n//2-m*(5**i)>(5**i)//2 :re+=n//2-m*(5**i)-(5**i)//2#print("pl2=" + str(n//2-m*(5**i)-(5**i)//2))if n%2 :for i in range(1,N+1) :#print("i="+str(i))a1=(5**i)//2+1 #首项#print("a1="+str(a1))d=(5**i)*2 #公差#print("d="+str(d))m=((n+1)//2)//(5**i) #完整段数#print("m="+str(m))re+=(2*a1+(m-1)*d)*m//2 #完整段等差数列求和#print("re1:" + str(re))re+=((n+1)//2-m*(5**i))*2*m #最后一段余项求和#print("re2:" + str(re)) #print("pl1=" + str(((n+1)//2-m*(5**i))*2*m))if (n+1)//2-m*(5**i)>(5**i)//2 :re+=(n+1)//2-m*(5**i)-(5**i)//2#print("pl2=" + str((n+1)//2-m*(5**i)-(5**i)//2))print(re)
相关文章:
题解 | #C.idol!!# 2023牛客暑期多校6
C.idol!! 数学 题目大意 正整数 n n n 的双阶乘 n ! ! n!! n!! 表示不超过 n n n 且与 n n n 有相同奇偶性的所有正整数乘积 求对于给定 n n n , ∏ i 1 n i ! ! \prod\limits_{i1}^n i!! i1∏ni!! 的后缀 0 0 0 个数 解题思路 根据双阶乘的性质&…...
使用filebeat收集并解析springboot日志
序 本文主要研究一下如何使用filebeat收集并解析springboot日志 安装 在官网的下载页面filebeat/downloads提供了一些特定平台的安装包,不过对应linux最为省事的安装方式就是直接下载x86_64压缩包,然后解压即可 wget https://artifacts.elastic.co/d…...
P1993 小 K 的农场
小 K 的农场 题目描述 小 K 在 MC 里面建立很多很多的农场,总共 n n n 个,以至于他自己都忘记了每个农场中种植作物的具体数量了,他只记得一些含糊的信息(共 m m m 个),以下列三种形式描述:…...
Spring boot 集成 Skywalking 配置 || Skywalking 打不开【已解决】
一、Skywalking官网 Apache SkyWalking 1.下载Skywalking APM (如果下载最新的,双击打开闪退,选老点的版本) 2. 下载 Skywalking Agents 如果下载太慢,建议复制下载链接,然后用下载器下载,比…...
手把手教你使用 ftrace 对 Linux 系统进行 debug
1、简介 strace:用来跟踪 Linux 进程执行时的系统调用和接收所接收的信号,可以跟踪到一个进程产生的系统调用,包括参数,返回值,执行消耗的时间。 ftrace:是一个 Linux 内核函数跟踪器,function tracer,旨在帮助开发人员和系统设计者可以找到内核内部发生的事情,从 L…...
【练】要求定义一个全局变量 char buf[] = “1234567“,创建两个线程,不考虑退出条件,打印buf
要求定义一个全局变量 char buf[] "1234567",创建两个线程,不考虑退出条件,另: A线程循环打印buf字符串,B线程循环倒置buf字符串,即buf中本来存储1234567,倒置后buf中存储7654321. 不…...
iOS Viper架构(中文版)【看懂这篇就够了】
完整源码地址 一、iOS_Viper iOS的Viper架构,作为一个从业多年的iOS开发者,我个人认为应该要会一点viper 二、前言 viper的设计模式在iOS开发中不流行,甚至是Swift中,也没有用,我认为比较可惜。作为iOSer,当你掌握…...
深入理解缓存 TLB 原理
今天分享一篇TLB的好文章,希望大家夯实基本功,让我们一起深入理解计算机系统。 TLB 是 translation lookaside buffer 的简称。首先,我们知道 MMU 的作用是把虚拟地址转换成物理地址。 MMU工作原理 虚拟地址和物理地址的映射关系存储在页表…...
获取k8s scale资源对象的命令
kubectl get --raw /apis/<apiGroup>/<apiVersion>/namespaces/<namespaceName>/<resourceKind>/<resourceName>/scale 说明:scale资源对象用来水平扩展k8s资源对象的副本数,它是作为一种k8s资源对象的子资源存在…...
基于ChatYuan-large-v2 语言模型 Fine-tuning 微调训练 广告生成 任务
一、ChatYuan-large-v2 ChatYuan-large-v2是一个开源的支持中英双语的功能型对话语言大模型,与其他 LLM 不同的是模型十分轻量化,并且在轻量化的同时效果相对还不错,仅仅通过0.7B参数量就可以实现10B模型的基础效果,正是其如此的…...
SpringBoot集成Logback日志
SpringBoot集成Logback日志 文章目录 SpringBoot集成Logback日志一、什么是日志二、Logback简单介绍三、SpringBoot项目中使用Logback四、概念介绍一、日志记录器Logger1.1、日志记录器对象生成1.2、记录器的层级结构1.3、过滤器1.4、logger设置日志级别1.5、java代码演示1.6、…...
MATLAB(R2023a)添加工具箱TooLbox的方法-以GPOPS为例
一、找到工具箱存放位置 首先我们需要找到工具箱的存放位置,点击这个设置路径可以看到 我们的matlab工具箱的存放位置 C:\Program Files\MATLAB\R2023a\toolbox\matlab 从资源管理器中打开这个位置,可以看到里面各种工具箱 二、放入工具箱 解压我们…...
助力618-Y的混沌实践之路 | 京东云技术团队
一、写在前面 1、混沌是什么? 混沌工程(Chaos Engineering)的概念由 Netflix 在 2010 年提出,通过主动向系统中引入异常状态,并根据系统在各种压力下的行为表现确定优化策略,是保障系统稳定性的新型手段。…...
Python系统学习1-4-物理行、逻辑行、选择语句
一、行 (1) 物理行:程序员编写代码的行。 (2) 逻辑行:python解释器需要执行的指令。 (3) 建议: 一个逻辑行在一个物理行上。 如果一个物理行中使用多个逻辑行,需要使用分号;隔开。 (4) 换行: 如果…...
学习系统编程No.35【基于信号量的CP问题】
引言: 北京时间:2023/8/2/12:52,时间飞逝,恍惚间已经来到了八月,给我的第一感觉就是快开学了,别的感觉其实没有,哈哈!看着身边的好友网络相关知识都要全部学完了,就好像…...
词嵌入、情感分类任务
目录 1.词嵌入(word embedding) 对单词使用one-hot编码的缺点是难以看出词与词之间的关系。 所以需要使用更加特征化的表示(featurized representation),如下图所示,我们可以得到每个词的向量表达。 假设…...
TypeScript使用技巧
文章目录 使用技巧TypeScript内置的工具类型keyofextends 限定泛型interface 与 type 区别 TypeScript作为JavaScript的超集,通过提供静态类型系统和对ES6新特性的支持,使JavaScript开发变得更加高效和可维护。掌握TypeScript的使用技巧,可以帮助我们更好地开发和组织JavaScrip…...
MySQL — InnoDB事务
文章目录 事务定义事务特性事务隔离级别READ UNCOMMITTEDREPEATABLE READREAD COMMITTEDSERIALIZABLE 事务存在的问题脏读(Dirty Read)不可重复读(Non-repeatable Read)幻读(Phantom Read) 事务定义 数据库…...
LeetCode 42. 接雨水(动态规划 / 单调栈)
题目: 链接:LeetCode 42. 接雨水 难度:困难 给定 n 个非负整数表示每个宽度为 1 的柱子的高度图,计算按此排列的柱子,下雨之后能接多少雨水。 示例 1: 输入:height [0,1,0,2,1,0,1,3,2,1,2…...
顺序表、链表刷题指南(力扣OJ)
目录 前言 题目一:删除有序数组中的重复项 思路: 题解: 题目二:合并两个有序数组 思路: 分析: 题解: 题目三:反转链表 思路: 分析: 题解: 题目四&…...
惊心动魄!从“卡脖子”到“心脏搭桥”,6台路由器带你亲历IPv6平滑迁移
摘要:从IPv4地址耗尽,到DNS根域服务器“卡脖子”风险,再到中国部署IPv6根服务器,网络协议的演进不仅关乎技术,更关乎国家战略。本文带你穿越互联网发展史,并通过eNSP搭建6台路由器的复杂拓扑,手把手演示如何在不重启设备、不影响业务的前提下,将网络从IPv4平滑迁移至IP…...
别再只盯着真值了!用AirSim API实战:如何正确解析无人机状态数据(附Python代码)
别再只盯着真值了!用AirSim API实战:如何正确解析无人机状态数据(附Python代码) 当你第一次从AirSim获取无人机状态数据时,可能会被返回的复杂字典结构弄得一头雾水。那些嵌套的Vector3r和Quaternionr对象,…...
OpenClaw跨平台实战:千问3.5-9B在mac与Windows的自动化对比
OpenClaw跨平台实战:千问3.5-9B在mac与Windows的自动化对比 1. 为什么需要跨平台对比 去年我在团队内部推广自动化工具时,遇到一个典型问题:同事们的开发环境分散在macOS和Windows两大平台。当我们尝试用OpenClaw千问3.5-9B构建统一自动化流…...
RAGFlow与Dify共存方案:同一台Win11机器如何用Docker隔离部署
RAGFlow与Dify共存方案:同一台Win11机器如何用Docker隔离部署 在AI应用开发领域,RAGFlow和Dify作为两款热门工具,分别擅长知识库构建和AI应用编排。许多开发者面临一个现实挑战:如何在本地开发环境中同时运行这两个系统࿱…...
OpenClaw日志分析:千问3.5-35B-A3B-FP8任务执行问题定位
OpenClaw日志分析:千问3.5-35B-A3B-FP8任务执行问题定位 1. 问题背景与日志分析的价值 上周我在尝试用OpenClaw自动化处理一批技术文档时,遇到了任务频繁中断的问题。当时对接的是千问3.5-35B-A3B-FP8模型,系统提示"模型响应异常"…...
2026做GEO,豆包、DeepSeek、元宝都爱引用哪些媒体?这份清单收好了!
你是不是也发现了这个 “诡异” 的现象?过去,我们拼命讨好搜索引擎的爬虫,优化关键词密度、买外链,只为排在百度搜索结果的第一页。而现在,用户变了。他们不再在搜索框里试错关键词,而是直接打开豆包、Deep…...
别再只用电容了!从π型RC到电子滤波,手把手教你选对硬件滤波方案(附电路图)
硬件滤波方案实战指南:从基础RC到电子滤波的工程决策 在嵌入式系统和电源设计中,噪声抑制是每个工程师必须面对的挑战。想象一下,你精心设计的传感器电路因为电源噪声导致数据跳变,或者音频放大器传出令人不快的嗡嗡声——这些问题…...
智谱CEO张鹏:将推理性能压榨至极限 不为短期盈利,而是为高质量Token消耗指数曲线
雷递网 乐天 3月31日智谱CEO张鹏今日在智谱2025年年报沟通会上表示,智谱曾经历过质疑,经历过挫折,但无数事实反复验证了一个判断——智能上界的提升,是大模型AGI时代唯一的"第一性"。张鹏说,AGI时代的商业价…...
编程小白的第一课:用快马AI零代码基础创建个人技能展示网站
作为一个刚接触编程的新手,我最近尝试用InsCode(快马)平台做了一个个人技能展示网站。整个过程比我预想的简单很多,特别适合零基础的同学上手。下面分享我的具体实现过程和心得: 项目规划与结构设计 刚开始完全不懂代码结构,但平台…...
CSS 滚动驱动动画:让页面动起来的新维度
CSS 滚动驱动动画:让页面动起来的新维度代码如诗,滚动如歌。让我们用滚动驱动动画的魔法,为用户带来沉浸式的浏览体验。什么是滚动驱动动画? 滚动驱动动画(Scroll-driven Animations)是 CSS 中一项革命性的…...
