题解 | #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)
目录 前言 题目一:删除有序数组中的重复项 思路: 题解: 题目二:合并两个有序数组 思路: 分析: 题解: 题目三:反转链表 思路: 分析: 题解: 题目四&…...
Chrome扩展开发实战:打造浏览器侧边栏ChatGPT助手
1. 项目概述:一个让ChatGPT常驻浏览器侧边栏的利器如果你和我一样,每天的工作和学习都离不开浏览器,并且频繁地与ChatGPT对话来获取灵感、润色文案或者调试代码,那么你肯定对在无数个标签页之间来回切换感到厌烦。每次都要打开一个…...
高考解析几何“秒杀”技巧:用极点极线快速搞定椭圆定点定值难题
高考解析几何“秒杀”技巧:用极点极线快速搞定椭圆定点定值难题 解析几何作为高考数学的压轴题型,常常让考生望而生畏。面对复杂的计算和抽象的条件,如何在有限时间内快速找到突破口?极点极线理论作为高等几何中的重要工具&#x…...
终极免费方案:3步轻松解锁QQ音乐加密文件,让音乐随处可听
终极免费方案:3步轻松解锁QQ音乐加密文件,让音乐随处可听 【免费下载链接】qmcflac2mp3 直接将qmcflac文件转换成mp3文件,突破QQ音乐的格式限制 项目地址: https://gitcode.com/gh_mirrors/qm/qmcflac2mp3 你是否曾遇到过这样的情况&a…...
NVIDIA Profile Inspector终极显卡优化工具:简单易用的性能调校完整指南
NVIDIA Profile Inspector终极显卡优化工具:简单易用的性能调校完整指南 【免费下载链接】nvidiaProfileInspector 项目地址: https://gitcode.com/gh_mirrors/nv/nvidiaProfileInspector NVIDIA Profile Inspector是一款专业的显卡优化工具,专为…...
移动端AI助手开发实战:混合架构、模型部署与性能优化
1. 项目概述:一个移动端AI助手的诞生 最近在移动端AI应用开发圈子里,一个名为 copaw-mobile 的项目开始引起不少同行的注意。这个由 xmingai 团队开源的项目,定位非常清晰——它要做的,就是将一个功能强大的AI助手,…...
ARM Neoverse-V3架构解析与性能优化实战
1. ARM Neoverse-V3架构概览作为Arm公司面向基础设施领域的最新处理器IP,Neoverse-V3代表了当前服务器级处理器的顶尖设计水平。我在实际芯片开发中多次接触该架构,其设计哲学可概括为:通过精细化微架构控制实现性能与能效的完美平衡。1.1 指…...
开源技能图谱工具SkillPort:Go语言构建的知识管理利器
1. 项目概述:一个技能图谱与知识管理的开源利器 最近在整理个人技术栈和团队知识库时,我一直在寻找一个能直观展示技能关联、又能深度管理学习路径的工具。市面上的笔记软件要么太“平”,只能线性记录;要么太“重”,像…...
基于Kubernetes Lease构建分布式部署锁:解决CI/CD环境下的资源竞争
1. 项目概述:从“clawfight”看一场被遗忘的社区技术博弈看到“2019-02-18/clawfight”这个标题,很多人的第一反应可能是困惑。它不像一个标准的软件项目名,没有清晰的版本号,也没有指明具体的技术栈。但恰恰是这种看似随意的命名…...
LC正弦波振荡器原理、设计与调试:从巴克豪森判据到电路实战
1. 从直流到交流:正弦波振荡器的核心价值与分类在电子电路的世界里,我们常常需要将稳定的直流电源,转换成特定频率和幅度的交流信号。这个看似“无中生有”的过程,正是正弦波振荡器的核心使命。无论是你手机里的无线通信模块、收音…...
基于Claude API构建可编程AI智能体:从对话到自动化生产单元
1. 项目概述:从Claude中“招聘”一个AI伙伴最近在GitHub上看到一个挺有意思的项目,叫“hire-from-claude”。初看这个标题,你可能会有点摸不着头脑:Claude不是Anthropic公司开发的那个AI助手吗?怎么还能从它那里“招聘…...
