2021-09-07 19:37:03 +08:00
|
|
|
from __future__ import annotations
|
2021-06-15 04:39:51 +08:00
|
|
|
|
|
|
|
|
2021-09-07 19:37:03 +08:00
|
|
|
def median(nums: list) -> int | float:
|
2019-07-11 04:38:10 +08:00
|
|
|
"""
|
|
|
|
Find median of a list of numbers.
|
2021-06-15 04:39:51 +08:00
|
|
|
Wiki: https://en.wikipedia.org/wiki/Median
|
2019-07-05 16:36:48 +08:00
|
|
|
|
2019-07-11 04:38:10 +08:00
|
|
|
>>> median([0])
|
|
|
|
0
|
2021-08-18 18:45:07 +08:00
|
|
|
>>> median([4, 1, 3, 2])
|
2019-07-11 04:38:10 +08:00
|
|
|
2.5
|
2020-08-21 14:39:03 +08:00
|
|
|
>>> median([2, 70, 6, 50, 20, 8, 4])
|
|
|
|
8
|
2019-07-05 16:36:48 +08:00
|
|
|
|
2019-07-11 04:38:10 +08:00
|
|
|
Args:
|
|
|
|
nums: List of nums
|
2019-07-05 16:36:48 +08:00
|
|
|
|
2019-07-11 04:38:10 +08:00
|
|
|
Returns:
|
|
|
|
Median.
|
|
|
|
"""
|
2023-08-16 05:27:41 +08:00
|
|
|
# The sorted function returns list[SupportsRichComparisonT@sorted]
|
|
|
|
# which does not support `+`
|
|
|
|
sorted_list: list[int] = sorted(nums)
|
2020-08-21 14:39:03 +08:00
|
|
|
length = len(sorted_list)
|
|
|
|
mid_index = length >> 1
|
|
|
|
return (
|
|
|
|
(sorted_list[mid_index] + sorted_list[mid_index - 1]) / 2
|
|
|
|
if length % 2 == 0
|
|
|
|
else sorted_list[mid_index]
|
|
|
|
)
|
2019-07-05 16:36:48 +08:00
|
|
|
|
2019-10-05 13:14:13 +08:00
|
|
|
|
2019-07-05 16:36:48 +08:00
|
|
|
def main():
|
2020-08-21 14:39:03 +08:00
|
|
|
import doctest
|
|
|
|
|
|
|
|
doctest.testmod()
|
2019-07-05 16:36:48 +08:00
|
|
|
|
2019-10-05 13:14:13 +08:00
|
|
|
|
|
|
|
if __name__ == "__main__":
|
2019-07-05 16:36:48 +08:00
|
|
|
main()
|