将一个正整数分解质因数。python3.6问题,输出为空,是哪里出了问题,求大神解答

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了将一个正整数分解质因数。python3.6问题,输出为空,是哪里出了问题,求大神解答相关的知识,希望对你有一定的参考价值。

i = int(input("请输入一个不小于2的正整数:"))
#判断质数的函数
def f(n):
a=2#可被乘数的计数器
for j in range(1, n+1):
if i % j == 0:
if j != 1 and j != i:
a += 1
else:
continue
else:
continue
return a

def p(t,l):
c = f(t)
if c == 2:
l.append(t)
else:
for h in range(2,t+1):
d = f(h)
if t%h == 0 and d == 2:
l.append(h)
p(t/h)
else:
continue

l = []
p(i,l)
for i in l:
print(i)
上面的代码不太清楚,我截了个图

第一是函数p(t,l)没有返回,在函数里修改列表l,是不能把结果带回的,还有后面的代码里使用了p(t/h),p函数需要两个参数,另外的代码也有一些问题,分解质因数推荐写成以下的形式

def p(n):
    l = []
    for i in range(2,n):
        if i*i>n:
            break
        while n%i==0:
            n //= i
            l.append(i)
    if n!=1:
        l.append(n)
    return l


i = int(input("请输入一个不小于2的正整数:"))
l = p(i)
print ("".join(['*'+str(l[i]) if i!=0 else str(l[i]) for i in range(len(l))]))

参考技术A 就是一个简单问题?怎么我刚做了你这复杂多了的东西,还有人问这个太简单等问题, 参考技术B 在整体代码来说,你只是调用了第二个函数,而第一个函数在第二个函数里被调用。当调用走完第一个函数的时候,重新回到了第二个函数,你的第二个函数,并没有return。。。

这是估计分析的,不知道对不对

Pythondemo实验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:
"))
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("
")
    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:
"))
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!
")
    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("
")
    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

 

以上是关于将一个正整数分解质因数。python3.6问题,输出为空,是哪里出了问题,求大神解答的主要内容,如果未能解决你的问题,请参考以下文章

将一个正整数分解质因数

Pythondemo实验17练习实例将一个正整数分解质因数

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

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

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

Go面试题:将一个正整数分解质因数 (Golang经典编程案例)