题目描述
给定 nnn 和 kkk,将从 1 到 nnn 之间的所有正整数可以分为两类:A 类数可以被 kkk 整除(也就是说是 kkk 的倍数),而 B 类数不能。请输出这两类数的平均数,精确到小数点后 111 位,用空格隔开。
数据保证两类数的个数都不会是 000。
输入格式
输入两个正整数 nnn 与 kkk。
输出格式
输出一行,两个实数,分别表示 A 类数与 B 类数的平均数。精确到小数点后一位。
输入输出样例
输入
100 16
输出
56.0 50.1
说明/提示
数据保证,1≤n≤100001 \leq n\leq 100001≤n≤10000,1≤k≤1001 \leq k \leq 1001≤k≤100。
方式
代码
class Solution:
@staticmethod
def oi_input():
"""从标准输入读取数据"""
num1, num2 = map(int, input().split())
return num1, num2
@staticmethod
def oi_test():
"""提供测试数据"""
return 100, 16
@staticmethod
def solution(num1, num2):
nums_a, nums_b = [], []
for i in range(1, num1 + 1):
if i % num2 == 0:
nums_a.append(i)
else:
nums_b.append(i)
print("{:.1f}".format(sum(nums_a) / len(nums_a)), "{:.1f}".format(sum(nums_b) / len(nums_b)))
oi_input = Solution.oi_input
oi_test = Solution.oi_test
solution = Solution.solution
if __name__ == '__main__':
num1, num2 = oi_test()
# num1, num2 = oi_input()
solution(num1, num2)

被折叠的 条评论
为什么被折叠?



