PTA 7-1 多二了一点 (15 分)

简介: 若一个正整数有 2n 个数位,后 n 个数位组成的数恰好比前 n 个数位组成的数多 2,则称这个数字“多二了一点”。

题目


若一个正整数有 2n 个数位,后 n 个数位组成的数恰好比前 n 个数位组成的数多 2,则称这个数字“多二了一点”。如 24、6668、233235 等都是多二了一点的数字。


给定任一正整数,请你判断它有没有多二了那么一点。


输入格式: 输入在第一行中给出一个正整数 N(≤10 1000 )。


输出格式: 在一行中根据情况输出下列之一:


如果输入的整数没有偶数个数位,输出 Error: X digit(s),其中 X 是 N 的位数; 如果是偶数位的数字,并且是多二了一点,输出 Yes: X - Y = 2,其中 X 是后一半数位组成的数,Y 是前一半数位组成的数; 如果是偶数位的数字,但并不是多二了一点,输出 No: X - Y != 2,其中 X 是后一半数位组成的数,Y 是前一半数位组成的数。


输入样例 1:
233235
结尾无空行
输出样例 1:
Yes: 235 - 233 = 2
结尾无空行
输入样例 2:
5678912345
结尾无空行
输出样例 2:
No: 12345 - 56789 != 2
结尾无空行
输入样例 3:
2331235
结尾无空行
输出样例 3:
Error: 7 digit(s)
结尾无空行

解题思路

inputStr = str(input())
# inputStr = str("233235")
if len(inputStr)%2 != 0:
    print("Error: "+str(len(inputStr))+" digit(s)")
else:
    length = len(inputStr)
    A1 = inputStr[:length//2]
    A2 = inputStr[length//2:]
    # print(A1,A2)
    A1Res,A2Res = 0,0
    for i in A1:
        A1Res += int(i)
    for i in A2:
        A2Res += int(i)
    # print(A1Res,A2Res)
    if (A2Res - A1Res) == 2:
        print("Yes: {} - {} = 2".format(A2, A1))
    else:
        print("No: {} - {} != 2".format(A2, A1))


目录
相关文章
【PTA】7-8 到底有多二 (15分)
【PTA】7-8 到底有多二 (15分)
2239 0
|
10月前
|
C语言
pta浙大版《C语言程序设计(第3版)》 习题6-4 使用函数输出指定范围内的Fibonacci数 (20分)
pta浙大版《C语言程序设计(第3版)》 习题6-4 使用函数输出指定范围内的Fibonacci数 (20分)
PTA 7-4 胖达与盆盆奶 (20 分)
俗称“胖达”,会排队吃盆盆奶。它们能和谐吃奶的前提,是它们认为盆盆奶的分配是“公平”的,即:更胖的胖达能吃到更多的奶,等胖的胖达得吃到一样多的奶。
206 0
|
测试技术
PTA 1039 到底买不买 (20 分)
小红想买些珠子做一串自己喜欢的珠串。卖珠子的摊主有很多串五颜六色的珠串,但是不肯把任何一串拆散了卖。
134 0
L1-057 PTA使我精神焕发 (5 分)
L1-057 PTA使我精神焕发 (5 分)
105 0
L1-057 PTA使我精神焕发 (5 分)
PTA 1046 划拳 (15 分)
划拳是古老中国酒文化的一个有趣的组成部分。酒桌上两人划拳的方法为:每人口中喊出一个数字,同时用手比划出一个数字。
131 0
|
测试技术
PTA 1011 A+B 和 C (15 分)
给定区间 [−2 31 ,2 31 ] 内的 3 个整数 A、B 和 C,请判断 A+B 是否大于 C。
131 0
PTA 1016 部分A+B (15 分)
正整数 A 的“D A ​ (为 1 位整数)部分”定义为由 A 中所有 D A ​ 组成的新整数 P A ​
109 0
PTA 1088 三人行 (20 分)
子曰:“三人行,必有我师焉。择其善者而从之,其不善者而改之。”
97 0