1.Sum of digits
说明:1.第一行包含要处理的值的数量;
2.然后N行将会描述这些数字的值应该是由3个整数A、B、C来计算的;
3.对于每一种情况,你需要将A乘以B,然后加上C(即A * B+C),然后计算结果的位数。
1 input data: 2 3 3 11 9 1 4 14 90 232 5 111 15 111 6 7 answer: 8 1 16 21
这里,第一种情况需要计算11*9+1=100,它的数字之和是1+0+0=1
1 A = [11, 14, 111] 2 B = [9, 90, 15] 3 C = [1, 232, 111] 4 5 for i in range(len(A)): 6 Num = A[i] * B[i] + C[i] 7 Sum = 0 8 while Num > 0: 9 if Num % 10 != 0: 10 Sum += Num % 10 11 Num = Num // 10 # 获得每位数的值 12 else: 13 Num = Num // 10 14 print(Sum, end=‘ ‘) 输出:1 16 21
2.Array Checksum
说明:1.您将得到一个用于计算校验和的数组。执行如下的计算:对于数组的每个元素,将这个元素添加到结果变量中,并将这个和乘以113——这个由10000007求模所取的新值应该成为结果的下一个值,以此类推。
2.输入数据将在第一行中显示数组的长度。
3.数组的值在第二行中,由空格分隔。
1 input data: 2 6 3 3 1 4 1 5 9 4 5 answer: 6 8921379
算法如下:
1 Arrays = [3, 1, 4, 1, 5, 9] 2 3 seed = 113 4 result = 0 5 limit = 10000007 6 for i in range(len(Arrays)): 7 result = (result + Arrays[i]) * seed 8 if 0 < result < 10000007: 9 result = result 10 else: 11 result = result % 10000007 # 大于10000007的值需要求模 12 13 print(result) 输出:8921379
时间: 2024-12-29 06:53:26