python计算阶乘方法

article/2025/10/3 12:19:01

1. 阶乘的概念

公式: n ! = ∏ k = 1 n k , ∀ n ≥ 1. n! = \prod_{k=1}^{n} k, \forall n\geq1. n!=k=1nk,n1.

2. 方法1:循环

# method 1. 
def factorial_1(n):if n<1:return 1res = 1for i in range(1, n+1):res *= ireturn res

测试:

prod_n = factorial_1(6)
print("prod", prod_n)#720

这里,也可以使用reduce来实现for循环,reduce() 函数会对参数序列中元素进行累积。
reduce() 函数的语法是:

reduce(function, iterable[,initalizer])

实现阶乘:

# method 2.
from functools import reduce
def factorial_2(n):if n<1:return 1res = reduce(lambda x,y:x*y, range(1,n+1))return res

3. 方法2:递归

循环的写法可以用递归来实现。

def factorial_3(n):if n == 0 or n == 1:return 1return factorial_3(n-1)*n

4. 方法3:math包实现

# method 4. math 
import math 
def factorial_4(n):res = math.factorial(n)return res

在python3中math包实用了分治算法,公式为:
在这里插入图片描述

具体的实现是:

# A pure Python version.# Returns the number of bits necessary to represent an integer in binary, 
# excluding the sign and leading zeros.
# Needed only for Python version < 3.0; otherwise use n.bit_length().
def bit_length(self):s = bin(self)       # binary representation:  bin(-37) --> '-0b100101's = s.lstrip('-0b') # remove leading zeros and minus signreturn len(s)       # len('100101') --> 6def num_of_set_bits(i) :# assert 0 <= i < 0x100000000i = i - ((i >> 1) & 0x55555555)i = (i & 0x33333333) + ((i >> 2) & 0x33333333)return (((i + (i >> 4) & 0xF0F0F0F) * 0x1010101) & 0xffffffff) >> 24def rec_product(start, stop):"""Product of integers in range(start, stop, 2), computed recursively.start and stop should both be odd, with start <= stop."""numfactors = (stop - start) >> 1if numfactors == 2 : return start * (start + 2)if numfactors > 1 :mid = (start + numfactors) | 1return rec_product(start, mid) * rec_product(mid, stop)if numfactors == 1 : return startreturn 1def binsplit_factorial(n):"""Factorial of nonnegative integer n, via binary split."""inner = outer = 1for i in range(n.bit_length(), -1, -1):inner *= rec_product((n >> i + 1) + 1 | 1, (n >> i) + 1 | 1)outer *= innerreturn outer << (n - num_of_set_bits(n))# Test (from math import factorial).
[[n, binsplit_factorial(n) - factorial(n)] for n in range(99)]

参考:

  1. binarysplitfact;
  2. github factorial;
  3. why-is-math-factorial-much-slower-in-python-2-x-than-3-x

http://chatgpt.dhexx.cn/article/QR9MUnEj.shtml

相关文章

Python计算阶乘(5种方法)

Python计算阶乘 第一次写博客&#xff0c;请多多指教 五种方法计算阶乘方法如下&#xff1a; 1.利用循环&#xff0c;如下代码演示 def main(num):a1for i in range(1,num1):a*ireturn aprint(main(10))执行结果如下&#xff1a; 2.导入functools中的reduce模块 from func…

python入门学习——6种方法求n的阶乘(8种写法)

一、阶乘&#xff08;factorial&#xff09; 自然数n&#xff01;&#xff08;n的阶乘&#xff09;是指从1、2……&#xff08;n-1&#xff09;、n这n个数的连乘积&#xff0c;即 n&#xff01;n&#xff08;n-1&#xff09;……21 如&#xff1a; 1&#xff01; 1 1 2&…

Fiddler模拟发送POST请求

在发起POST请求时不像GET请求可以在浏览器地址栏直接输入&#xff0c;POST请求的参数是放在请求体中的&#xff0c;因此如果想要模拟POST请求&#xff0c;需要借助工具&#xff0c;比如Postman或者Fiddler&#xff0c;这里简单介绍一下Fiddler模拟Post请求的方法。 输入请求ur…

轻松把玩HttpClient之模拟post请求示例

HttpClient 是 Apache Jakarta Common 下的子项目&#xff0c;可以用来提供高效的、最新的、功能丰富的支持 HTTP 协议的客户端编程工具包&#xff0c;并且它支持 HTTP 协议最新的版本和建议。当前官网最新版介绍页是&#xff1a;http://hc.apache.org/httpcomponents-client-4…

IDEA模拟post发送请求

第一步&#xff1a; 第二步&#xff1a; 发送请求准备 第三步&#xff1a;查看结果

Python 模拟浏览器 POST请求思路

Python 模拟浏览器发送POST请求思路 昨天朋友找我说想对一个tp网站的视频刷播放量&#xff0c;说可以一个IP地址无限刷。 登陆到网站后对所需的视频进行点击播放&#xff0c;发现没有任何跳转&#xff0c;而是发送了个POST请求。 这样一看&#xff0c;我们用requests就可以完…

Java模拟发送post请求

项目要求&#xff1a;模拟100个温湿度设备发送温湿度数据进行压测&#xff0c;查看数据是否有叠加且显示正确&#xff0c;因为测试环境简陋&#xff0c;没有100个温湿度设备&#xff0c;只能通过调用接口模拟发送请求&#xff0c;由于每次发送的请求要求正文某些元素值要唯一&a…

简单实用的Chrom浏览器模拟POST请求方式

实现post请求方式有很多种&#xff0c;比如postman等。 但有时候接口做了登录拦截&#xff0c;这个时候使用postman等工具要配置相关的cookie信息。 这个过程是很繁琐&#xff0c;最后也不一定能达到预期效果。 本篇使用chrom的console控制台&#xff0c;满足你的诉求 步骤如下…

浏览器模拟跨站跨域请求或post请求

var xhr new XMLHttpRequest(); xhr.open("GET", "http://localhost:8080/hello/hi"); xhr.send(null); xhr.onload function(e) { var xhr e.target; console.log(xhr.responseText); } 打开跨站源网站&#xff0c;例如www.baidu.com&#xff…

模拟get和post请求

一、模拟请求&#xff08;浏览器及工具模拟&#xff09; http请求有很多种&#xff0c;常用的请求方式有两种&#xff1a;get请求和post请求&#xff0c;今天先介绍浏览器以及工具模拟请求&#xff0c;下次会介绍代码模拟 1、get请求格式&#xff1a; url&#xff1f;param1va…

Qt4.8.6 Embedded Linux 的编译与移植

最近买了个飞凌ok6410 的开发板&#xff0c;于是在其中搭建qt4.8.6运行环境。费了两三天时间&#xff0c;主要还是对linux系统的生疏&#xff0c;在一些问题上徘徊很久&#xff0c;在这里做一些过程笔记。烧写ARM-Linux系统&#xff0c;根据飞凌官方的用户手册成功为开发板烧写…

麻辣香锅病毒处置

麻辣香锅病毒介绍 “麻辣香锅“病毒由于其早期版本病毒模块所在目录为” Mlxg_km “因此得名&#xff0c;该病毒通过小马激活&#xff0c;暴风激活&#xff0c;KMS激活等激活工具进行传播&#xff0c;用户中毒后首页会被劫持到病毒作者预设的跳转链接 病毒恶意行为流程图&…

【原创】ES5高效封装WIN10系统教程2020系列(三)母盘安装及系统调整

** 本教程共有7个系列 ** 1. 母盘定制 2. 准备封装环境 3. 母盘安装及系统调整 4. 使用工具优化与清理 5. 常用软件安装及设置 6. ES5封装 7. 测试效果 母盘安装没有什么难度&#xff0c;第一章系统定制已经得到了精简的install.wim母盘映像文件&#xff0c;并且已经拷贝到数…

Exp2 后门原理与实践

20155332《网络对抗》Exp2 后门原理与实践 1.实验环境 主机一台联想台式机&#xff0c;安装有win10系统 。安装的kali虚拟机为攻击机。我的win10系统作为靶机。&#xff08;建议再安装一个虚拟机作为靶机&#xff0c;不要像我这么做。我电脑有点卡&#xff0c;就没有安装那么多…

Win10正式版激活方法有哪些?如何激活Win10?

很多用户都想将系统升级到Win10,但是却不知道怎么激活Win10正式版的方法,其实不同版本激活正式版Win10的方法秘钥不同,下面99安卓网小编就分享一些激活Win10正式版的方法和秘钥,供大家参考。 目前win10正式版已经发布,相信已经有非常多的Win7/Win8.1用户升级安装了Win10正…

win10一键激活,解除SymantecEndpointProtection的自动拦截

破解背景&#xff1a; win10系统&#xff0c;电脑预装有SymantecEndpointProtection安全软件&#xff0c;每次采用小马KMS等激活工具激活系统的时候回自动拦截掉&#xff0c;贼烦。 破解原理&#xff1a; 相关原理可查看来自蓝点网的转载连接&#xff1a;https://mp.weixin.…

Windows常用软件推荐

前言 很多人都认为我是计算机高手,其实我只会帮你修理下你的电脑啦,曾几何时我也帮助过好多好多的同学和老师,尝试和体验各种各样的软件,但谁又能想到我曾今也对你们的电脑做过很多失败的坑爹操作,把你们最宝贵的数据撸得灰飞烟灭,这里要感谢当时允许我不断尝试失败的大…

第二十三期:你用的Windows操作系统是不是盗版?微软知道吗

长期以来,一些小白对于微软操作系统的“正版”“盗版”“原版”的含义不太明确,从根本上说Windows原始版权属于微软,我们没有那个技术去开发盗版操作系统,很多人用的可能是二次修改的版本,而操作系统的激活方式,决定其成为正版或者盗版。 长期以来,一些小白对于微软操作…

俺可爱的小马,差点被淹了

时间&#xff1a;2008年8月6日&#xff0c;下午 地点&#xff1a;北京中关村软件园 一场突然急速的暴雨&#xff0c;在短短十几分钟的时间内&#xff0c;就起水二十多厘米深&#xff0c;眼看水快漫过我的“白色小马&#xff08;千里马&#xff09;”的排气管&#xff0c;只好冒…

WIN10 解决“无法完成操作,因为文件包含病毒或潜在的垃圾软件”

新装了win 10 系统&#xff0c;一路遇到了一堆的问题&#xff0c;有空详述 今天在激活的时候 &#xff0c;本来想找个产品密钥激活&#xff0c;但是找了很多个都不能成功&#xff0c;最终选择下载激活工具 第一次下载了KMSpico小马激活工具&#xff0c;解压安装系统提示 傻夫…