洛谷题单3-P5719 【深基4.例3】分类平均-python-流程图重构

题目描述

给定 n n n 和 k k k,将从 1 到 n n n 之间的所有正整数可以分为两类:A 类数可以被 k k k 整除(也就是说是 k k k 的倍数),而 B 类数不能。请输出这两类数的平均数,精确到小数点后 1 1 1 位,用空格隔开。

数据保证两类数的个数都不会是 0 0 0。

输入格式

输入两个正整数 n n n 与 k k k。

输出格式

输出一行,两个实数,分别表示 A 类数与 B 类数的平均数。精确到小数点后一位。

输入输出样例

输入

复制代码
100 16

输出

复制代码
56.0 50.1

说明/提示

数据保证, 1 ≤ n ≤ 10000 1 \leq n\leq 10000 1≤n≤10000, 1 ≤ k ≤ 100 1 \leq k \leq 100 1≤k≤100。

方式

代码

python 复制代码
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)

流程图

是 否 是 否 是 否 开始 读取输入num1和num2 初始化nums_a和nums_b 遍历1到num1的所有数 能否被num2整除? 加入nums_a 加入nums_b 继续下一个数 计算平均值 nums_a是否为空? avg_a = 0.0 avg_a = sum_a / len_a nums_b是否为空? avg_b = 0.0 avg_b = sum_b / len_b 格式化输出两位小数 结束

相关推荐
橘猫云计算机设计7 分钟前
springboot基于hadoop的酷狗音乐爬虫大数据分析可视化系统(源码+lw+部署文档+讲解),源码可白嫖!
数据库·hadoop·spring boot·爬虫·python·数据分析·毕业设计
YOULANSHENGMENG12 分钟前
linux 下python 调用c++的动态库的方法
c++·python
牛马baby22 分钟前
Java高频面试之并发编程-07
java·开发语言·面试
CodeWithMe28 分钟前
【C++】STL之deque
开发语言·c++
SsummerC29 分钟前
【leetcode100】零钱兑换Ⅱ
数据结构·python·算法·leetcode·动态规划
一眼青苔1 小时前
切割PDF使用python,库PyPDF2
服务器·python·pdf
炯哈哈1 小时前
【上位机——MFC】运行时类信息机制
开发语言·c++·mfc·上位机
电商数据girl1 小时前
产品经理对于电商接口的梳理||电商接口文档梳理与接入
大数据·数据库·python·自动化·产品经理
好易学·数据结构1 小时前
可视化图解算法:二叉树的最大深度(高度)
数据结构·算法·二叉树·最大高度·最大深度·二叉树高度·二叉树深度
程序员-King.1 小时前
day47—双指针-平方数之和(LeetCode-633)
算法·leetcode