日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

python 實現在無序數組中找到中位數方法

瀏覽:45日期:2022-08-04 13:28:27

一、問題描述

1求一個無序數組的中位數, (若數組是偶數,則中位數是指中間兩個數字之和除以2,若數組是奇數,則中位數是指最中間位置。要求:不能使用排序,時間復雜度盡量低

2例如:

lists = [3, 2, 1, 4] , 中位數為 = (2+3)/2 = 2.5lists = [3, 1, 2] , 中位數為 2

3、算法思想:

利用快速排序思想(但是并不是全部使用):任意挑選一個元素,以該元素為key, 劃分數組為兩個部分,如果左側數組長度剛好為(n-1)/2, 那么key就為中位數, 若左側數組長度 < (n-1)/2 , 那么中位數點在右側,反之,中位數在左側。然后進入相應的一側繼續尋找中位

平均時間復雜度為O(n)

二、程序

class Solution(object): def findmedian(self, lists): if not lists or len(lists) == 0: return [] n = len(lists) if n % 2 == 0: a = self.partition(lists, n/2, 0, n-1) b = self.partition(lists, n/2-1, 0, n-1) mid = (lists[a]+lists[b])/ (2 * 1.0) return mid else: mid = self.partition(lists, n/2, 0, n-1) return lists[mid] def partition(self, lists, k, start, end): key = lists[start] left, right = start, end while left < right: while left < right and lists[right] > key: right = right - 1 lists[left] = lists[right] while left < right and lists[left] < key: left = left + 1 lists[right] = lists[left] lists[left] = key if left == k: return left elif left > k: return self.partition(lists, k, start, left-1) else: return self.partition(lists, k, left+1, end) if __name__ == '__main__': sol = Solution() lists = [2, 5, 4, 9, 3, 6, 8, 7, 1] # lists = [1, 2] data = sol.findmedian(lists) print('中位數 = %s' % data)

知識補充:python streaming 實現某個字段排序

一,hadoop streaming默認情況

1,在hadoop streaming的默認情況下,是以t作為分隔符的,標準輸入時,每行的第一個t之前的內容作為key,第一個t之后的內容作為value。注意,如果一個t字符都沒有,那么整行作為key。

2,streaming的一些參數如下:

-D stream.map.output.field.separator :設置map輸出中key和value的分隔符 -D stream.num.map.output.key.fields : 設置map程序分隔符的位置,該位置之前的部分作為key,之后的部分作為value -D map.output.key.field.separator : 設置map輸出中key內部的分割符-D num.key.fields.for.partition : 指定分桶時,key按照分隔符切割后,其中用于分桶key所占的列數(配合-partitioner org.apache.hadoop.mapred.lib.KeyFieldBasedPartitioner 使用)-D stream.reduce.output.field.separator:設置reduce輸出中key和value的分隔符 -D stream.num.reduce.output.key.fields:設置reduce程序分隔符的位置

二,python streaming 實現某個字段的排序

1, 輸入數據: cat data.txt (中間是tab鍵)

11 211 311 4 111 1

11 12 22

2,streaming程序如下:

vim sorted.sh

#!/bin/bashexport CURRENT=/home/chunhe.liao/hadoop_streaming/sort/usr/local/hadoop-2.6.3/bin/hadoop jar /usr/local/hadoop-2.6.3/share/hadoop/tools/lib/hadoop-streaming-2.6.3.jar -D stream.map.output.field.separator=’t’ -D stream.num.map.output.key.fields=3 -D mapreduce.job.output.key.comparator.class=org.apache.hadoop.mapreduce.lib.partition.KeyFieldBasedComparator -D mapreduce.partition.keycomparator.options=-k3,3nr # 按照第三列逆序排列,可以根據想要的第幾段來選擇。-input '/user/test/inputdata/datas3/data.txt' -output '/user/test/streaming/sorted_20180711' -mapper 'python mapper.py' -reducer 'python reducer.py' -file '$CURRENT/mapper.py' -file '$CURRENT/reducer.py'

(2) mapper.py

# -*- coding: utf-8 -*-import sys for line in sys.stdin: line = line.strip() print(’{0}’.format(line))

(3) reducer.py

# -*- coding: utf-8 -*-import sys for line in sys.stdin: line = line.strip() print('{0}'.format(line))

運行命令:

bash sorted.sh

運行結果:

hdfs dfs -cat /user/test/streaming/sorted_20180711/part-00000

11 12 2211 311 211 4 111 1

以上這篇python 實現在無序數組中找到中位數方法就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Python 編程
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
黄色av一区| 国产乱人伦精品一区| 国产一区二区三区不卡视频网站 | 国产精品一国产精品k频道56| 国产精品一卡| 日韩在线短视频| 噜噜噜久久亚洲精品国产品小说| **爰片久久毛片| 欧美日韩视频免费观看| 日本欧洲一区二区| 久久久久伊人| 激情综合网五月| 欧美一级全黄| 麻豆网站免费在线观看| 亚洲作爱视频| 国产精品免费大片| 欧美精品羞羞答答| 国产欧美精品久久| 免费视频国产一区| 久久精品97| 亚洲天堂成人| 国产精品羞羞答答在线观看| 天使萌一区二区三区免费观看| 亚洲精品进入| 精品一区二区男人吃奶| 亚洲91视频| 婷婷综合福利| 高清久久一区| 9久re热视频在线精品| 日本亚洲不卡| 91亚洲一区| 视频一区欧美日韩| 国产精品啊v在线| 欧美色图国产精品| 久久亚洲国产精品一区二区| 欧美自拍一区| 国产一区二区三区四区五区| 午夜精品亚洲| 国产精品分类| 伊人成人网在线看| 国产精品黄色片| 激情综合亚洲| 欧美日韩精品一区二区三区视频 | 激情自拍一区| 欧美日韩亚洲一区三区| 日韩大片在线观看| 蜜臀久久久久久久| 欧美视频久久| 久久免费高清| 国产不卡一区| 不卡在线一区二区| 精品国产免费人成网站| 欧美一区在线观看视频| 国产视频一区在线观看一区免费| 国产+成+人+亚洲欧洲在线| 日本vs亚洲vs韩国一区三区二区| 午夜久久久久| 92国产精品| 美女在线视频一区| 日韩av字幕| 丝袜美腿亚洲一区二区图片| 亚洲天堂1区| 久久一区亚洲| 亚洲精品1区| 国产精品福利在线观看播放| 亚洲综合五月| 欧美日韩精品一区二区视频| 国产精品久久久久77777丨| 黄色成人精品网站| 国产成人精品一区二区三区免费| 亚洲精品黄色| 免费国产自久久久久三四区久久 | 亚洲涩涩av| 天堂8中文在线最新版在线| 天海翼精品一区二区三区| 韩国精品主播一区二区在线观看| 欧美精品观看| 亚洲在线免费| 在线看片国产福利你懂的| 日本aⅴ亚洲精品中文乱码| 91九色精品| 国产美女高潮在线| 日韩国产91| 日韩视频一区二区三区在线播放免费观看| 久久精品国产999大香线蕉| 中文一区一区三区免费在线观 | 精品日韩一区| 国产精品美女午夜爽爽| 欧美日韩一区二区三区四区在线观看 | 国模大尺度视频一区二区| 国产精品一区免费在线| 欧美日韩中文| 国产日韩一区二区三区在线| 国产日韩在线观看视频| 国产精品久一| 日韩高清在线不卡| 在线观看亚洲精品福利片| 欧美日韩视频一区二区三区| 成人午夜国产| 国产a久久精品一区二区三区| 国产精品片aa在线观看| 天堂久久一区| 中文字幕亚洲精品乱码| 99视频精品免费观看| 欧美 日韩 国产精品免费观看| 精品久久影院| 麻豆视频观看网址久久| 国产欧美日韩亚洲一区二区三区| 香蕉久久久久久| 天海翼亚洲一区二区三区| 免费久久99精品国产| 亚洲欧美日本视频在线观看| 9色国产精品| 国产一区二区高清| 99日韩精品| 久久亚洲国产精品一区二区| 欧美在线亚洲| 亚洲国产综合在线看不卡| 国产综合精品一区| av一区二区高清| aa亚洲婷婷| 免费久久精品视频| 婷婷综合成人| 日韩一区二区三区免费视频| 日韩高清在线一区| 欧美日本久久| 国产极品模特精品一二| 国产福利一区二区三区在线播放| 国产一区二区中文| 亚洲不卡视频| 精品日韩一区| 久久久精品五月天| 水野朝阳av一区二区三区| 欧美一级网址| 丁香六月综合| 日韩精品一级中文字幕精品视频免费观看 | 日本不卡视频在线观看| 国产精区一区二区| 国产日韩高清一区二区三区在线| 国产精品115| 成人在线视频免费看| 中文字幕系列一区| 99香蕉国产精品偷在线观看| 蜜臀久久99精品久久久画质超高清| 久久亚洲图片| 91精品国产自产观看在线| 久久精品人人| 国产99久久| 亚洲日本久久| 久久av超碰| 欧美日韩视频免费观看| 欧美日韩国产欧| 午夜在线精品| 国产精品一区免费在线| 成人小电影网站| 亚洲在线一区| 国产精品日本一区二区三区在线| 日本一二区不卡| 亚洲精品中文字幕乱码| 日韩在线黄色| 福利一区二区免费视频| 黄色不卡一区| 97久久亚洲| 在线精品亚洲欧美日韩国产| 先锋影音国产一区| 欧美交a欧美精品喷水| 激情久久五月| 日本不卡的三区四区五区| 日本黄色精品| 视频一区国产视频| 精品久久久网| 另类国产ts人妖高潮视频| 国产精品中文字幕亚洲欧美| 亚洲欧美日本国产专区一区| 国产精品久久久久久久久久白浆 | 日韩中文字幕一区二区三区| 精品不卡一区| 日日夜夜免费精品| 欧美亚洲国产激情| 精品久久免费| 日韩成人在线看| 99国产精品视频免费观看一公开 | 国产在线观看www| 久久国产高清| 国产在线日韩精品| 视频一区国产视频| av中文字幕在线观看第一页| 免费一级片91| 热三久草你在线| 日韩精品免费观看视频| 日韩电影免费在线观看| 人人精品久久| 极品日韩av| 精品深夜福利视频| 蜜臀av在线播放一区二区三区 | 色乱码一区二区三区网站| 六月天综合网| 中文字幕色婷婷在线视频| 亚洲2区在线| 国产一区亚洲|