【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. -------------------------------------------------- ...
随机推荐
- BZOJ 2982 combination 脑子+组合数学
可以发现,整个数列构成一个树形结构,并且是个完全二叉堆(小根堆). 并且这个堆的形态在给定$n$后是固定的,第1个位置上显然只能放1. 对子树的根来说,他自己是所分得的数集中最小的那个,所以从剩下$s ...
- Windows操作系统中的I/O(读/写 输入/输出)
导言 写一个Windows平台下的应用程序大多时候都是离不开读写文件,网络通信的. 比如一个服务应用程序来说,它可能从网络适配器接受用户的请求,对请求进行处理计算,最终将用户端所需的数据返回,中间可能 ...
- HDU 4635 Strongly connected ——(强连通分量)
好久没写tarjan了,写起来有点手生,还好1A了- -. 题意:给定一个有向图,问最多添加多少条边,让它依然不是强连通图. 分析:不妨考虑最大时候的临界状态(即再添加一条边就是强连通图的状态),假设 ...
- nodejs豆瓣爬虫
从零开始nodejs系列文章,将介绍如何利Javascript做为服务端脚本,通过Nodejs框架web开发.Nodejs框架是基于V8的引擎,是目前速度最快的Javascript引擎.chrome浏 ...
- Asyncio之EventLoop笔记
使用事件循环 Python3.4 采用了一个强大的框架来支持代码的并发执行: asyncio.这个框架使用事件循环来编排回调和异步任务. 事件循环位于事件循环策略的上下文中-这是 asyncio 所特 ...
- Nginx之进程间的通信机制(Nginx频道)
1. Nginx 频道 ngx_channel_t 频道是 Nginx master 进程与 worker 进程之间通信的常用工具,它是使用本机套接字实现的,即 socketpair 方法,它用于创建 ...
- How to get full path of StreamWriter
How to get full path of StreamWriter In my version of the framework, this seems to work: string f ...
- code备忘
按空白符分隔(正则) String[] split = line.trim().split("\\s+");
- linux 自动输入用户名和密码 ftp
参考文章: http://blog.sina.com.cn/s/blog_8709e3120101culd.html 方法概括; 1.echo管道 2. 利用重定向操作符command <&l ...
- [jquery]JSON.parse()与JSON.stringify()
JSON.parse()[从一个字符串中解析出json对象] 例子: //定义一个字符串 var data='{"name":"goatling"}' //解析 ...