题目描述
给定 𝑛n 和 𝑘k,将从 1 到 𝑛n 之间的所有正整数可以分为两类:A 类数可以被 𝑘k 整除(也就是说是 𝑘k 的倍数),而 B 类数不能。请输出这两类数的平均数,精确到小数点后 11 位,用空格隔开。
数据保证两类数的个数都不会是 00。
输入格式
输入两个正整数 𝑛n 与 𝑘k。
输出格式
输出一行,两个实数,分别表示 A 类数与 B 类数的平均数。精确到小数点后一位。
输入输出样例
输入 #1复制
100 16
输出 #1复制
56.0 50.1
说明/提示
数据保证,1≤𝑛≤100001≤n≤10000,1≤𝑘≤1001≤k≤100。
代码:
#include<iostream>
#include<cstdio>
using namespace std;
int main() {
int n, k; cin >> n >> k;
int num1 = 0, num2 = 0;
double sum1 = 0.0, sum2 = 0.0;
for (int i = 1; i <= n; i++) {
if (i % k == 0) {
num1 += 1;
sum1 += (i * 1.0);
}
else {
num2 += 1;
sum2 += (i * 1.0);
}
}
sum1 = sum1 / (num1 * 1.0);
sum2 = sum2 / (num2 * 1.0);
printf("%.1f %.1f\n", sum1, sum2);
return 0;
}
719

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



