題目:中位數(shù)就是一組數(shù)據(jù)從小到大排列后中間的那個(gè)數(shù)字。如果數(shù)組長(zhǎng)度為偶數(shù),那么中位數(shù)的值就是中間兩個(gè)數(shù)字相加除以2,如果數(shù)組長(zhǎng)度為奇數(shù),那么就是中間那個(gè)數(shù)。
讓客戶滿意是我們工作的目標(biāo),不斷超越客戶的期望值來自于我們對(duì)這個(gè)行業(yè)的熱愛。我們立志把好的技術(shù)通過有效、簡(jiǎn)單的方式提供給客戶,將通過不懈努力成為客戶在信息化領(lǐng)域值得信任、有價(jià)值的長(zhǎng)期合作伙伴,公司提供的服務(wù)項(xiàng)目有:國(guó)際域名空間、雅安服務(wù)器托管、營(yíng)銷軟件、網(wǎng)站建設(shè)、陳倉(cāng)網(wǎng)站維護(hù)、網(wǎng)站推廣。
分析:采用類快速排序的方法,把問題轉(zhuǎn)化為求一列數(shù)中第i小的數(shù)的問題,求中位數(shù)就是求一列數(shù)的第(len(arr)/2 + 1)小的數(shù)的問題)。
當(dāng)使用依次類快速排序算法后,分割元素的下標(biāo)為pos:
(1)當(dāng)pos len(arr) / 2時(shí),說明中位數(shù)在數(shù)組左半部分,在左半部分繼續(xù)查找。
(2)當(dāng)pos == len(arr) / 2,說明找到中位數(shù)arr[pos]。
(3)當(dāng)pos len(arr) / 2, 說明中位數(shù)在數(shù)組右半部分,在右半部分繼續(xù)查找。
以上默認(rèn)此數(shù)組序列長(zhǎng)度為奇數(shù),如果為偶數(shù)就是調(diào)用上述方法兩次查找中間的兩個(gè)數(shù),再求平均。
code:
def partition(arr, low, high):
key = arr[low]
while low high:
? ? while low high and arr[high] key:
? ? ? ? high -= 1
? ? arr[low] = arr[high]
? ? while low high and arr[low] key:
? ? ? ? low += 1
? ? arr[high] = arr[low]
arr[high] = arr[low]
arr[low] = key
pos = low
return pos
def getMid(arr):
low = 0
high = len(arr) - 1
mid = low + (high - low) 1
while low high:
? ? # 以arr[low] 為基準(zhǔn)把數(shù)組分成兩部分
? ? pos = partition(arr, low, high)
? ? if pos == mid:? # 找到中位數(shù)
? ? ? ? break
? ? elif pos mid:? # 繼續(xù)在右半部分查找
? ? ? ? high = pos - 1
? ? else:? # 繼續(xù)在左半部分查找
? ? ? ? low = pos + 1
# 如果數(shù)組長(zhǎng)度為奇數(shù),中位數(shù)為中間的元素,否則就是中間兩個(gè)數(shù)的平均值
return arr[mid] if (len(arr) % 2) != 0 else (arr[mid] + arr[mid + 1]) / 2
if __name__ == "__main__":
arr = [7, 5, 3, 1, 2,? 11, 9]
print(getMid(arr))
程序的運(yùn)行結(jié)果為:6
分位數(shù)就是 可以 將 數(shù)據(jù) 等分 若干份的 數(shù)
一組數(shù)據(jù)
從小到大排序后
運(yùn)行結(jié)果
使用python找到一列數(shù)的中位數(shù)并輸出的代碼示例如下,只有9行代碼:
import random;
N=9;lst=[
random.randint(0,100)
for i in range(N)];
lst.sort();
l=len(lst);
print("sorted:",lst);
print("median:",
sum(lst[((l-1)//2):(l//2+1)])/2);
def?median(lst):
if?not?lst:
return?
lst=sorted(lst)
if?len(lst)%2==1:
return?lst[len(lst)//2]
else:
return??(lst[len(lst)//2-1]+lst[len(lst//2])/2.0
# coding=gbk
import numpy as np
inputStr = input("請(qǐng)輸入多個(gè)整數(shù),以空格分隔:")
# 使用列表推導(dǎo)式將輸入的內(nèi)容以空格分隔,如果有小數(shù),則通過int函數(shù)變?yōu)檎麛?shù)
input_lists = [int(num) for num in inputStr.split(" ")]
# 通過sort方法,并使用參數(shù)reverse=True,來將列表的數(shù)據(jù)以降序排列
input_lists.sort(reverse=True)
# 由于通過",".join()連接的列表不能有整數(shù)元素,所以通過列表推導(dǎo)式將列表每個(gè)元素通過str轉(zhuǎn)為字符串后,再聯(lián)接為以逗號(hào)分隔的字符串
print(",".join([str(num) for num in input_lists]))
# 使用numpy的median函數(shù)來得到中位數(shù)
print(np.median(input_lists))
中位數(shù)通常比平均值更有用。中位數(shù),統(tǒng)計(jì)學(xué)中的專有名詞,代表一個(gè)樣本、種群或概率分布中的一個(gè)數(shù)值,其可將數(shù)值集合劃分為相等的上下兩部分,python的平均值是中位數(shù)是因?yàn)橹形粩?shù)通常比平均值更有用,Python由荷蘭數(shù)學(xué)和計(jì)算機(jī)科學(xué)研究學(xué)會(huì)的GuidovanRossum于1990年代初設(shè)計(jì),作為一門叫做ABC語(yǔ)言的替代品。
名稱欄目:函數(shù)中位數(shù)python,函數(shù)的中位數(shù)
網(wǎng)址分享:http://chinadenli.net/article32/hdodsc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供靜態(tài)網(wǎng)站、品牌網(wǎng)站建設(shè)、營(yíng)銷型網(wǎng)站建設(shè)、品牌網(wǎng)站設(shè)計(jì)、微信公眾號(hào)、面包屑導(dǎo)航
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)