【Python】【demo实验17】【练习实例】【将一个正整数分解质因数】
题目:将一个正整数分解质因数。例如:输入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】【练习实例】【将一个正整数分解质因数】的更多相关文章
- 【python】将一个正整数分解质因数
def reduceNum(n): '''题目:将一个正整数分解质因数.例如:输入90,打印出90=2*3*3*5''' print '{} = '.format(n), : print 'Pleas ...
- C# 练习题 将一个正整数分解质因数
题目:将一个正整数分解质因数.例如:输入90,打印出90=2*3*3*5.程序分析:对n进行分解质因数,应先找到一个最小的质数k,然后按下述步骤完成:(1)如果这个质数恰等于n,则说明分解质因数的过程 ...
- 利用matlab实现以下功能:将一个正整数分解质因数。例如:输入90,打印出90=2*3*3*5。
程序思路: 对n进行分解质因数,应先找到一个最小的质数k,从2开始,然后按下述步骤完成: (1)如果这个质数恰等于n,则说明分解质因数的过程已经结束,打印出即可. (2)如果n不等于k,则应打印出k的 ...
- java将一个正整数分解质因数。例如:输入90,打印出90=2*3*3*5。
首先我们的算法是:例如 输入的是 90 1.找到90的最小公约数(1除外)是 2 2.然后把公约数 2 输出 3.接着用 90 / 2 = 45 (如果这里是素数,就结束,否则继续找最小公约数) 4. ...
- 【Python3练习题 010】将一个正整数分解质因数。例如:输入90,打印出90=2*3*3*5。
#参考http://www.cnblogs.com/iderek/p/5959318.html n = num = int(input('请输入一个数字:')) #用num保留初始值 f = [] ...
- python基础练习题(题目 将一个整数分解质因数。例如:输入90,打印出90=2*3*3*5)
day9 --------------------------------------------------------------- 实例014:分解质因数 题目 将一个整数分解质因数.例如:输入 ...
- 将一个正整数分解为m个2的n次方的和
-- ============================================= -- Author: <maco_wang> -- Create date: & ...
- python分解质因数
将一个正整数分解质因数.例如:输入90,打印出90=2*3*3*5. # !/usr/bin/env python # -*- coding:utf-8 -*- # Author:Hiuhung Wa ...
- Python练习题 010:分解质因数
[Python练习题 010]将一个正整数分解质因数.例如:输入90,打印出90=2*3*3*5. -------------------------------------------------- ...
随机推荐
- yarn是什么?
yarn是个包管理器.你可以通过它使用全世界开发者的代码, 或者分享自己的代码. 从 npm 安装软件包并保持相同的包管理流程. 优点: 1.速度超快. Yarn 缓存了每个下载过的包 ...
- 小技巧——直接在目录中输入cmd然后就打开cmd命令窗口
直接在目录中输入cmd然后就打开cmd命令窗口
- HDU 5544 Ba Gua Zhen ( 2015 CCPC 南阳 C、DFS+时间戳搜独立回路、线性基 )
题目链接 题意 : 给出一副简单图.要你找出一个回路.使得其路径上边权的异或和最大 分析 : 类似的题有 BZOJ 2115 对于这种异或最长路的题目(走过的边可以重复走) 答案必定是由一条简单路径( ...
- webstorm 格式化代码及常用快捷键 Option+Command+l
mac 下 webstorm 格式化代码的快捷键 Option+Command+l
- 图像傅里叶变换(快速傅里叶变换FFT)
学习DIP第7天,图像傅里叶变换 转载请标明出处:http://blog.csdn.net/tonyshengtan,欢迎大家转载,发现博客被某些论坛转载后,图像无法正常显示,无法正常表达本人观点,对 ...
- Codeforces 1106E. Lunar New Year and Red Envelopes(DP)
E. Lunar New Year and Red Envelopes 题意: 在长度为n的时间轴上,有k个红包,每个红包有领取时间段[s,t],价值w,以及领了个这个红包之后,在时间d到来之前无法再 ...
- Mybatis源码学习之类型转换(四)
简述 JDBC数据类型与Java语言中的数据类型并不是完全对应的,所以在PreparedStatement为SQL语句绑定参数时,需要从Java类型转换成JDBC类型,而从结果集中获取数据时,则需要从 ...
- 丰桥运单打印windows/linux环境安装(原)
Linux ①linux下安装jdk1.8,执行命令:yum -y install java ②创建文件夹sf-service将csim_waybill_print_service_V1.0.3.ja ...
- 函数柯里化与偏函数+bind
简单理解: 1,函数柯里化就是把多参数函数分解为多return的单参数函数: 举个例子(伪代码): function func (a, b, c){ return } 柯里化为 function fu ...
- 【零基础】搞定LAMP(linux、apache、mysql、php)环境安装图文教程(基于centos7)
一.前言 LAMP即:Linux.Apache.Mysql.Php,也就是在linux系统下运行php网站代码,使用的数据库是mysql.web服务软件是apache.之所以存在LAMP这种说法,倒不 ...