阶乘是基斯顿·卡曼(Christian Kramp,1760~1826)于 1808 年发明的运算符号。一个正整数的阶乘(factorial)是所有小于及等于该数的正整数的积,通俗的讲也就是按顺序从1乘到n,所得的那个数就是n的阶乘。0的阶乘为1,自然数n的阶乘写作n!。即:0!= 11!= 12!= 2 × 1!= 2 × 13!= 3 × 2!= 3 × 2 × 1n!= n × (n - 1)!= n × (n - 1) × (n - 2) ×...× 2 × 1
输入一个整数n,求其阶乘n!
双阶乘用“m!!”表示。
当 m 是自然数时,表示不超过 m 且与 m 有相同奇偶性的所有正整数的乘积。如:
当 m 是负奇数时,表示绝对值小于它的绝对值的所有负奇数的绝对值积的倒数。
当 m 是负偶数时,m!!不存在。
自然数双阶乘比的极限
阶乘的逼近函数公式
对于正整数
第1行: 定义变量a,用input函数使用户输入数字,int函数将其转换为整型
第2行: 创建一个存储阶乘运算结果的变量result,变量初始值为1
第3-10行: 用if...elif...else语句对用户输入的数值进行判断。若用户输入的数值小于0,输出“负数没有阶乘”;若用户输入的数值等于0,输出“0的阶乘为1”;否则用for循环遍历1 至 a 的整数,在每轮循环中,result都会与循环变量 i 相乘并将乘积结果再赋值给result,当for循环结束时,result的值就是自然数n阶乘的运算结果,最后用print函数输出阶乘结果。
第1行: 定义函数factorial,传入参数n
第2行: 用assert断言函数限定参数n大于或等于0,若大于或等于0,执行后面的代码,否则报错“AssertionError: 请输入自然数!
第3-5行: 设定递归的结束条件,当 n 为 0时,返回值为1,否则返回值为n * factorial(n - 1)
第8行: 定义变量a,用input函数使用户输入数字,int函数将其转换为整型
第9行: 为参数n赋值为a,用print函数打印计算结果
第1行: 从functools模块中导入reduce()函数
第4行: 定义函数factorial,传入参数n
第5行: 用assert断言函数限定参数n大于或等于0,若大于或等于0,执行后面的代码,否则报错“AssertionError: 请输入自然数!”
第6-7行: 设定递归的结束条件,当 n 为 0时,返回值为1
第8行: 调用reduce函数,使用lambda 表达式输出前n项的积
第11行: 定义变量a,用input函数使用户输入数字,int函数将其转换为整型
第12行: 为参数n赋值为a,用print函数打印计算结果
educe() 函数
reduce() 函数是functools模块中的一个函数,其作用是对参数序列中元素进行累积。
语法:reduce(function, iterable[, initializer])
参数说明:function:是包含两个参数的函数iterable :可迭代对象initializer :初始参数
def prod(x, y):函数prod有两个参数x和y,迭代对象是[1,2,3,4,5],计算过程为((((1+2)+3)+4)+5),在函数function的两个参数中,左边的参数x是被累积的值,而右边的参数y是依次从序列中获取的值。可以使用lambda表达式来简化代码:
print(reduce(lambda x, y: x + y, [1, 2, 3, 4, 5])) # 15lambda 表达式
Lambda 函数是Python中的匿名函数,也就是没有具体名称的函数,通常是在需要一个函数,但是又不想费神去命名一个函数的场合下使用 。
lambda 表达式的两个要点:
第1行: 导入模块math
第2行: 定义变量a,用input函数使用户输入数字,int函数将其转换为整型
第3行: 创建变量result,调用math模块中的factorial函数,传入参数a
第4行: print函数输出结果
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
长按识别二维码并关注微信
更方便到期提醒、手机管理