Python练习题001

文章介绍了如何使用编程解决一个涉及递推关系的问题,给定两个整数a和n,计算并输出一个特定的数值表达式。给出了两种简化算法的时间和空间复杂度分析。样例展示了输入和输出的计算过程。

【问题描述】

输入两个整数a(大于等于1且小于等于9)和n(大于等于1且小于等于80),编程求得并输出下面等式的值:

例如:若输入的a为5,n为6,则要计算下面公式的值:

555555-55555-5555-555-55-5。

【输入形式】

从标准输入读入整数a和n,两者之间以一个空格分隔。

【输出形式】

在标准输出上输出公式的计算结果。

【样例1输入】

5 6
【样例1输出】

493830
【样例1说明】

输入的a为5,n为6,按照上述公式计算的结果为493830。

【样例2输入】

5 20
【样例2输出】

49382716049382716060
【样例2说明】

输入的a为5,n为20,按照上述公式计算的结果为49382716049382716060。

【评分标准】

该程序要求输出求得的公式的值。

a,n=map(int,input().split()) #第二题初代想法 时间O(n),空间O(n)
number=[]
temp = 0
for j in range(n):
    temp=temp+a*(10**j)
    number.append(temp)
differ=number[n-1]
for ele in range(0,n-1):
    differ=differ-number[ele]
print(differ)



a,n=map(int,input().split()) #第二题 简化时间O(n),空间O(1)
a=-a
temp = 0
differ = 0
for j in range(n):
    temp=temp+a*(10**j)
    if j == n-1:
        temp=-temp
    differ=differ+temp
print(differ)

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值