【Python CheckiO 题解】Median


CheckiO 是面向初学者和高级程序员的编码游戏,使用 Python 和 JavaScript 解决棘手的挑战和有趣的任务,从而提高你的编码技能,本博客主要记录自己用 Python 在闯关时的做题思路和实现代码,同时也学习学习其他大神写的代码。

CheckiO 官网:https://checkio.org/

我的 CheckiO 主页:https://py.checkio.org/user/TRHX/

CheckiO 题解系列专栏:https://itrhx.blog.csdn.net/category_9536424.html

CheckiO 所有题解源代码:https://github.com/TRHX/Python-CheckiO-Exercise


题目描述

【Median】:给定一个数组,查找其中位数,如果数组的元素个数是偶数,则返回中间两个元素的平均值。

【链接】https://py.checkio.org/mission/median/

【输入】:由整数组成的数组(list)

【输出】:数组的中位数(int or float)

【前提】:1 < len(data) ≤ 1000;all(0 ≤ x < 10 ** 6 for x in data)

【范例】

checkio([1, 2, 3, 4, 5]) == 3
checkio([3, 1, 2, 5, 3]) == 3
checkio([1, 300, 2, 200, 1]) == 2
checkio([3, 6, 20, 99, 10, 15]) == 12.5

解题思路

先用 sort() 方法将数组元素按照从小到大排序,利用数组的长度除以 2 来判断其元素个数是奇数还是偶数。

代码实现

from typing import List


def checkio(data: List[int]) -> [int, float]:
    data.sort()
    if len(data) % 2 == 0:
        return (data[int(len(data)/2) - 1] + data[int(len(data)/2)])/2
    else:
        return data[int(len(data)/2)]


# These "asserts" using only for self-checking and not necessary for auto-testing
if __name__ == '__main__':
    print("Example:")
    print(checkio([1, 2, 3, 4, 5]))

    assert checkio([1, 2, 3, 4, 5]) == 3, "Sorted list"
    assert checkio([3, 1, 2, 5, 3]) == 3, "Not sorted list"
    assert checkio([1, 300, 2, 200, 1]) == 2, "It's not an average"
    assert checkio([3, 6, 20, 99, 10, 15]) == 12.5, "Even length"
    print("Start the long test")
    assert checkio(list(range(1000000))) == 499999.5, "Long."
    print("Coding complete? Click 'Check' to earn cool rewards!")

大神解答

大神解答 NO.1

from typing import List
from statistics import median

def checkio(data: List[int]) -> [int, float]:
    return median(data)

statistics 模块的 median 方法可以直接求中位数!

大神解答 NO.2

from typing import List

def checkio(data: List[int]) -> [int, float]:
    data = sorted(data)
    l = len(data) 
    return [(data[l//2]+data[l//2-1])/2, data[l//2]][l%2]

大神解答 NO.3

from typing import List

def checkio(data):
    data.sort()
    half = len(data) // 2
    return (data[half] + data[~half]) / 2
发布了145 篇原创文章 · 获赞 511 · 访问量 45万+
展开阅读全文

没有更多推荐了,返回首页

©️2019 CSDN 皮肤主题: 数字20 设计师: CSDN官方博客

分享到微信朋友圈

×

扫一扫,手机浏览