• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >C语言 > 千万不要被阶乘吓倒

千万不要被阶乘吓倒

作者: 字体:[增加 减小] 来源:互联网 时间:2017-05-28

通过本文主要向大家介绍了不要被困难吓倒,不要被失败吓倒,不要被困难吓倒的诗句,不要被风雪吓倒,不要被困难吓倒作文等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com
阶乘(Factorial)是个很有意思的函数,但是不少人都比较怕它,我们来看看两个与阶乘相关的问题:
1、 给定一个整数N,那么N的阶乘N!末尾有多少个0呢?例如:N=10,N!=3 628 800,N!的末尾有两个0。
2、求N!的二进制表示中最低位1的位置。
有些人碰到这样的题目会想:是不是要完整计算出N!的值?如果溢出怎么办?事实上,如果我们从"哪些数相乘能得到10"这个角度来考虑,问题就变得简单了。
首先考虑,如果N!= K×10^M,且K不能被10整除,那么N!末尾有M个0。再考虑对N!进行质因数分解,N!=(2^x)×(3^y)×(5^z)…,由于10 = 2×5,所以M只跟X和Z相关,每一对2和5相乘可以得到一个10,于是M = min(X, Z)。不难看出X大于等于Z,因为能被2整除的数出现的频率比能被5整除的数高得多,所以把公式简化为M = Z。
根据上面的分析,只要计算出Z的值,就可以得到N!末尾0的个数。
【问题1的解法一】
要计算Z,最直接的方法,就是计算i(i =1, 2, …, N)的因式分解中5的指数,然后求和:
</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 千万不要被阶乘吓倒

相关文章

  • 2017-05-28C++如何实现DNS域名解析
  • 2017-05-28linux c 获取本机公网IP的实现方法
  • 2017-05-28c++中typename和class的区别介绍
  • 2017-05-28从汇编看c++中变量类型的深入分析
  • 2017-05-28深入理解strcpy与memcpy的区别
  • 2017-05-28C++中基类和派生类之间的转换实例教程
  • 2017-05-28C++ sizeof 实例解析
  • 2017-05-28C语言实现输出链表中倒数第k个节点
  • 2017-05-28C++中点操作符和箭头操作符的使用详解
  • 2017-05-28C语言中的fscanf()函数与vfscanf()函数使用

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • 在C++中反射调用.NET的方法(三)
    • 深入解析C++设计模式编程中解释器模式的运用
    • 有关C++继承与友元、继承与类型转换详解
    • 详谈C++何时需要定义赋值/复制构造函数
    • c++ #include是怎么样工作的?
    • 筛选法的C++实现
    • SublimeText编译C开发环境设置
    • 简单谈谈关于C++中大随机数的问题
    • C++拷贝构造函数(深拷贝与浅拷贝)详解
    • VC++简单实现关机、重启计算机实例代码

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有