文章目录
前言🍀
小学生算术🗽
🗽问题描述
🗽问题分析
🗽代码实现
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="")
这就是今天分享的全部内容啦!实现并不难但是思想非常的重要。希望大家能熟练掌握。