0
点赞
收藏
分享

微信扫一扫

【Python 百炼成钢】 小学生算术、阶乘的精确值、孪生素数、6174问题

自信的姐姐 2022-03-11 阅读 31

文章目录

前言🍀

小学生算术🗽


🗽问题描述

🗽问题分析

🗽代码实现

import sys
flag=0
lis=[]
num=0
while True:
    m,n=sys.stdin.readline().strip().split()
    m,n=int(m),int(n)
    if n==m==0:
        break
    # 只要m,n经过变换有一个为0那么循环就终止
    while m and n:
        if (m%10+n%10+flag)>=10:
            num+=1
            flag=1
        else:
            flag=0
        m//=10
        n//=10
    lis.append(num)
    num=0
for i in lis:
    print(i)

阶乘精确值🐳


🐳问题描述

🐳问题分析

🐳代码实现

import time
def timmer(func):
    def weapper(*s):
        start=time.time()
        func(*s)
        end=time.time()
        print("用时:",end-start)
    return weapper

@timmer
def f1(n):
    # 直接计算
    ans=1
    # 用于标记现在是所在的位数
    if n==0 or n==1:
        print(1)
        exit()
    else:
        for i in range(2,n+1):
            ans=ans*i
                
    print(ans)
@timmer
def f2(n):
    # C语言方法精确计算
    ans=[0]*1000
    ans[0]=1
    for i in range(2,n+1):
        j=0
        c=0
        while j<1000:
            temp=ans[j]*i+c
            ans[j]=temp%10
            c=temp//10
            j+=1

    i=len(ans)-1
    flag=True
    while i>=0:
        if flag and ans[i]==0:
            pass
        else:
            print(ans[i],end="")
            flag=False
        i-=1
    print()

if __name__=="__main__":
    n=int(input())
    # f1(n)
    f2(n)
    

孪生素数🛸


🛸问题描述

🛸问题分析

🛸代码实现

def is_ok(num):
    if num==1:
        return False
    for i in range(2,int(math.sqrt(num))+1):
        if num%i==0:
            return False
    return True


n=int(input())
while n:
    if is_ok(n) and is_ok(n-2):
        print(n-2,n)
        break
    n-=1

6174问题🎱


🎱问题描述

🎱问题分析

🎱代码实现

# 自定义排序函数,如果r=True就是降序
def msort(n,r=True):
    ans=0
    temp=[]
    //将数值转换为列表
    while n:
        temp.append(n%10)
        n//=10
    #在刚刚进行排序的时候高位与低位进行了颠倒,再颠倒回来
    temp=temp[::-1]
    #排序
    temp=sorted(temp,reverse=r)
    # 将列表组合成数值并返回出去
    for i in temp:
        ans=ans*10+i
    return ans


ans=[]
n=int(input())
ans.append(n)
while True:
	# 得到最大最小值
    maxn=msort(n)
    minn=msort(n,False)
    temp=maxn-minn
    ans.append(temp)
    if n==temp:
        break
    n=temp
flag=True
for i in ans:
    if flag:
        print(i,end="")
        flag=False
    else:
        print("--->",i,end="",sep="")

这就是今天分享的全部内容啦!实现并不难但是思想非常的重要。希望大家能熟练掌握。


ᴴᴬᵛᴱ ᴬ ᴳᴼᴼᴰ ᵀᴵᴹᴱฅʕ•̫͡•ʔฅ 🕺🏿🕺🏿⚰️🕺🏿🕺🏿

举报

相关推荐

0 条评论