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

我的源代码:

#!/usr/bin/python
# encoding=utf-8
# -*- coding: UTF-8 -*- # 将一个正整数分解质因数。例如:输入90,打印出90=2*3*3*5。 a = int(input("please input the number:\n"))
b = a
# a 的因数集合
la = [] l = [] c = int(a*0.5)+2
print("c: ==> ",c) for i in range(2,c):
if i !=2 and i%2==0:
continue
elif i !=3 and i%3==0:
continue
elif i !=5 and i%5==0:
continue
elif i !=7 and i%7==0:
continue
elif i !=11 and i%11==0:
continue
elif i !=13 and i%13==0:
continue
elif i !=17 and i%17==0:
continue
elif i !=19 and i%19==0:
continue
elif i !=23 and i%23==0:
continue
elif i !=29 and i%29==0:
continue #print(i,"###")
if a%i==0:
la.append(i)
a = a/i
while(1):
if a%i==0:
la.append(i)
a =a/i
else:
break
if len(la) == 0:
la.append(1)
la.append(b) print(b," = ",end=" ")
for i in range(len(la)):
print(la[i],end=" ")
if i==len(la)-1:
print("\n")
else :
print(" * ",end=" ")

此代码的弊端,就是对于一个稍微大一点的数,但是其质因子都是比较小的数,处理起来太浪费时间:

所以想过,对于大一些的数的处理逻辑:

1、先建立一个数字y以内的质数表

2、优先查看这个大数所包含的质数表内的所有质因子;

3、对于质因子不在列表范围内的,再执行搜索程序;(这个比较耗时间)

优化后的代码(对于较大的数字,都能以稍快一些的时间处理完):

#!/usr/bin/python
# encoding=utf-8
# -*- coding: UTF-8 -*- # 将一个正整数分解质因数。例如:输入90,打印出90=2*3*3*5。 a = int(input("please input the number:\n"))
b = a
# a 的因数集合
la = []
x = 0
#y = 1000000 #用于判断计算质数列表的最大临界
y = 300000 #用于判断计算质数列表的最大临界 if 1:
# 先构建一个质数列表:
l = []
for i in range(2,y):
k = 1
if i == 2:
l.append(i)
continue
else :
m = int(i ** 0.5) #square root
for j in range(2,m):
if i%j == 0:
k = 0;
#print(i,"is not a prime.")
break
if k == 1:
l.append(i)
#print("list: ",l) #排查这个数对应的列表内的质因子: for n in range(len(l)):
#print(n,"###")
if a%l[n]==0:
la.append(l[n])
a = a/l[n]
while(1):
if a%l[n]==0:
la.append(l[n])
a =a/l[n]
else:
break
c = 1 #c用于标记la列表的个数之积是否等于a for o in range(len(la)):
c = c * la[o]
if c == b:
x = 1 #x用于标记a这个数的质因子是否全部找到了,如果为1,表示全部找到了;x默认为0; # 第一步处理完毕;
d = int(a)
f = int(a) """
print(b," = ",end=" ")
for i in range(len(la)):
print(la[i],end=" ")
if i==len(la)-1:
print("* the new number!\n")
else :
print(" * ",end=" ")
"""
# print("==> d = ",d)
# 下一步的数据循环点;
# 只用于计算较大的质因子。 if x == 0:
e = int(d*0.5)+2
# print("==> e = ",e)
if y<e: #对于特别大的数字a;
for i in range(y,e): #我得去判断y比e大还是小啊;
print(i,"###")
if d%i==0:
la.append(i)
x = 2 #标记la列表有增加;
d = d/i
while(1):
if d%i==0:
la.append(i)
d =d/i
else:
break
else :
for i in range(2,e): #我得去判断y比e大还是小啊;
print(i,"###")
if d%i==0:
la.append(i)
x = 2 #标记la列表有增加;
d = d/i
while(1):
if d%i==0:
la.append(i)
d =d/i
else:
break
if x == 0: #表明d本身为质数,为a的质因数;
#print("2:",la,"f:",f)#
la.append(f)
#print("1:",la)# # 对于输入的数字为质数的情况;
if len(la) == 0:
la.append(1)
la.append(b)
# 这里面实际将1当做质数了,如果默认1不为质数,那么可以输出:a是质数;无质因子; print(b," = ",end=" ")
for i in range(len(la)):
print(la[i],end=" ")
if i==len(la)-1:
print("\n")
else :
print(" * ",end=" ")

处理结果:

原题给出的解答:

————————(我是分割线)————————

参考:

1. RUNOOB.COM:https://www.runoob.com/python/python-exercise-example14.html

备注:

初次编辑时间:2019年9月29日19:14:24

环境:Windows 7   / Python 3.7.2

【Python】【demo实验17】【练习实例】【将一个正整数分解质因数】的更多相关文章

  1. 【python】将一个正整数分解质因数

    def reduceNum(n): '''题目:将一个正整数分解质因数.例如:输入90,打印出90=2*3*3*5''' print '{} = '.format(n), : print 'Pleas ...

  2. C# 练习题 将一个正整数分解质因数

    题目:将一个正整数分解质因数.例如:输入90,打印出90=2*3*3*5.程序分析:对n进行分解质因数,应先找到一个最小的质数k,然后按下述步骤完成:(1)如果这个质数恰等于n,则说明分解质因数的过程 ...

  3. 利用matlab实现以下功能:将一个正整数分解质因数。例如:输入90,打印出90=2*3*3*5。

    程序思路: 对n进行分解质因数,应先找到一个最小的质数k,从2开始,然后按下述步骤完成: (1)如果这个质数恰等于n,则说明分解质因数的过程已经结束,打印出即可. (2)如果n不等于k,则应打印出k的 ...

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

    首先我们的算法是:例如 输入的是 90 1.找到90的最小公约数(1除外)是 2 2.然后把公约数 2 输出 3.接着用 90 / 2 = 45 (如果这里是素数,就结束,否则继续找最小公约数) 4. ...

  5. 【Python3练习题 010】将一个正整数分解质因数。例如:输入90,打印出90=2*3*3*5。

    #参考http://www.cnblogs.com/iderek/p/5959318.html n = num = int(input('请输入一个数字:'))  #用num保留初始值 f = []  ...

  6. python基础练习题(题目 将一个整数分解质因数。例如:输入90,打印出90=2*3*3*5)

    day9 --------------------------------------------------------------- 实例014:分解质因数 题目 将一个整数分解质因数.例如:输入 ...

  7. 将一个正整数分解为m个2的n次方的和

    -- ============================================= -- Author:      <maco_wang> -- Create date: & ...

  8. python分解质因数

    将一个正整数分解质因数.例如:输入90,打印出90=2*3*3*5. # !/usr/bin/env python # -*- coding:utf-8 -*- # Author:Hiuhung Wa ...

  9. Python练习题 010:分解质因数

    [Python练习题 010]将一个正整数分解质因数.例如:输入90,打印出90=2*3*3*5. -------------------------------------------------- ...

随机推荐

  1. parents([expr]) 取得一个包含着所有匹配元素的祖先元素的元素集合(不包含根元素)。可以通过一个可选的表达式进行筛选。

    parents([expr]) 概述 取得一个包含着所有匹配元素的祖先元素的元素集合(不包含根元素).可以通过一个可选的表达式进行筛选.大理石平台检定规程   参数 exprStringV1.0 用于 ...

  2. EnumHelper.cs

    网上找的,还比较实用的: using System; using System.Collections.Generic; using System.ComponentModel; using Syst ...

  3. node中fs内置模块

    Node.js内置的fs模块就是文件系统模块,负责读写文件. 和所有其它JavaScript模块不同的是,fs模块同时提供了异步和同步的方法. 回顾一下什么是异步方法.因为JavaScript的单线程 ...

  4. nginx的ngx_str_t

    在nginx里的ngx_tr_t结构是字符串定义如下 typedef struct { size_t len; u_char *data; }ngx_str_t; 在给这样的结构体赋值的时候,ngin ...

  5. python 找出数组重复的元素

    """ 从头扫到尾,只要当前元素值与下标不同,就做一次判断,numbers[i]与numbers[numbers[i]], 相等就认为找到了重复元素,返回true,否则就 ...

  6. 【零基础】speech driven animation中文安装使用指南

    注:原项目名叫Speech-Driven Animation,所以我这里就简称为SDA 开局一张图,后面自动编 相信前段时间爆火的DeepNude(AI扒衣)让很多人惊掉了大牙,AI还能干这个?!如果 ...

  7. flask静态html

    flask使用静态html 在flask并不是所有的html都需要做成动态html,并且做成动态html在使用静态资源时要改变它的路径.所以我们有些可以使用静态html. 静态html不需要后台渲染, ...

  8. 【SQL】 java.sql.SQLException: You can't specify target table 'emp' for update in FROM clause

    在执行sql: delete from emp where id in (select id from emp where cdate<'2018-02-02') 时报出以下异常: ### Th ...

  9. easyUI之progressbar进度条

    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <hea ...

  10. 堡垒机直接调用RUN

    两个脚本 Run.vbe   参考https://blog.csdn.net/skypeGNU/article/details/12708221 set ws=wscript.createobject ...