Python编程基础题(15-A除以B)

Description
本题要求计算 A/B,其中 A 是不超过 1000 位的正整数,B 是 1 位正整数。你需要输出商数 Q 和余数 R,使得 A=B×Q+R 成立。

Input
输入在一行中依次给出 A 和 B,中间以 1 空格分隔。

Output
在一行中依次输出 Q 和 R,中间以 1 空格分隔。

Sample Input
123456789050987654321 7

Sample Output
123456789050987654321 7

参考程序

def List_To_Str(A):
    ans=""
    for i in range(len(A)):
        if i==0 and A[i]==0 and len(A)!=1:
            continue
        else:
            ans+=str(A[i])
    return ans

def Div(A,B):#A是字符串,B是一位整数
    tempQ=[]
    for i in range(len(A)):
        tempQ.append(int(A[:i+1])//B)
        A="0"*i+str(int(A[:i+1])%B)+A[i+1:]
    return (tempQ,A[-1])


inp=input()
string=inp.split()[0]
number=int(inp.split()[1])
ans=Div(string,number)
Q=List_To_Str( ans[0] )
R=ans[1]
print("{0} {1}".format(Q,R))

注:
本题为PAT (Basic Level) Practice1017题。
若直接将输入转换为整数计算,会得到“非零返回”的异常提示,显然题目给出的评测数据A是超出整型的表示范围的。因此需要用最“原始”的做法,用计算机模拟手算的过程。
Div函数执行Div(“1234”,9)的过程如下图所示:
在这里插入图片描述
List_To_Str函数就是将商(由若干整数构成的列表)化为字符串输出出来,而且也要注意商的第一位不能是0。特别要注意被除数小于除数的情况,因为在这种情况下,商仅一位,且为0,这个时候是要输出的。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值