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

相关推荐
qq_252614411 分钟前
python爬虫爬取视频
开发语言·爬虫·python
Swift社区5 分钟前
LeetCode 453 - 最小操作次数使数组元素相等
算法·leetcode·职场和发展
PNP Robotics5 分钟前
聚焦具身智能,PNP机器人展出力反馈遥操作,VR动作捕捉等方案,获得中国科研贡献奖
大数据·人工智能·python·学习·机器人
咸鱼加辣8 分钟前
【python面试】你x的启动?
开发语言·python
八月ouc8 分钟前
Python实战小游戏(二): 文字冒险游戏
数据结构·python·文字冒险
hoiii18711 分钟前
LR算法辅助的MIMO系统Zero Forcing检测
算法
糖葫芦君13 分钟前
Lora模型微调
人工智能·算法
Blossom.11817 分钟前
多模态大模型实战:从零实现CLIP与电商跨模态检索系统
python·web安全·yolo·目标检测·机器学习·目标跟踪·开源软件
EXtreme3517 分钟前
【数据结构】二叉树进阶:层序遍历不仅是按层打印,更是形态判定的利器!
c语言·数据结构·二叉树·bfs·广度优先搜索·算法思维·面试必考
小李小李快乐不已22 分钟前
二叉树理论基础
数据结构·c++·算法·leetcode