python实例100第14例:将一个正整数分解质因数

**题目:**将一个正整数分解质因数。例如:输入90,打印出90=2*3*3*5。

程序分析: 对n进行分解质因数,应先找到一个最小的质数k,然后按下述步骤完成:

(1)如果这个质数恰等于n,则说明分解质因数的过程已经结束,打印出即可。

(2)如果n<>k,但n能被k整除,则应打印出k的值,并用n除以k的商,作为新的正整数你n,重复执行第一步。

(3)如果n不能被k整除,则用k+1作为k的值,重复执行第一步。

程序源代码:

python 复制代码
#!/usr/bin/python
# -*- coding: UTF-8 -*-
 
def reduceNum(n):
    print '{} = '.format(n),
    if not isinstance(n, int) or n <= 0 :
        print '请输入一个正确的数字 !'
        exit(0)
    elif n in [1] :
        print '{}'.format(n)
    while n not in [1] : # 循环保证递归
        for index in xrange(2, n + 1) :
            if n % index == 0:
                n /= index # n 等于 n/index
                if n == 1: 
                    print index 
                else : # index 一定是素数
                    print '{} *'.format(index),
                break
reduceNum(90)
reduceNum(100)

以上实例输出结果为:

90 = 2 * 3 * 3 * 5

100 = 2 * 2 * 5 * 5

相关推荐
m0_74675230几秒前
如何用方法简写语法在对象字面量中快速定义成员函数
jvm·数据库·python
qq_189807033 分钟前
JavaScript 中高效定位二维数组间不匹配元素的行列索引
jvm·数据库·python
程序员大雄学编程4 分钟前
微积分40. 有理函数的积分法(上)
python·微积分
qq_349317486 分钟前
Python GUI界面如何实现主题美化_引入ttk模块实现原生外观风格
jvm·数据库·python
yuanpan6 分钟前
Python Scrapy 入门教程:从零学会抓取和解析网页数据
java·python·scrapy
hnjzsyjyj12 分钟前
全排列问题DFS实现执行示意图
数据结构·dfs
Lumos_77713 分钟前
Linux -- 系统调用
linux·运维·算法
forEverPlume14 分钟前
c++如何通过解析二进制包头信息解决Socket传输过程中的粘包问题【详解】
jvm·数据库·python
玉小格21 分钟前
对py作业的一个复盘
开发语言·python
BU摆烂会噶21 分钟前
【LangGraph 持久化】让 AI Agent 拥有“记忆”
数据库·人工智能·python·langchain