亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費(fèi)注冊 查看新帖 |

Chinaunix

  平臺 論壇 博客 文庫
最近訪問板塊 發(fā)新帖
查看: 3279 | 回復(fù): 4
打印 上一主題 下一主題

求大神寫一段程序。謝謝。 [復(fù)制鏈接]

論壇徽章:
0
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報告]
發(fā)表于 2015-01-07 22:48 |只看該作者 |倒序?yàn)g覽
本帖最后由 yxycsgs 于 2015-01-07 22:49 編輯

data.txt中每一行一個數(shù),行數(shù)隨便。算出這些數(shù)的平均值m和標(biāo)準(zhǔn)差x,把那些小于m-3x的和大于m+3x的數(shù)去掉,改寫了原文件。然后在剩下的數(shù)中重復(fù)上述過程,直到?jīng)]有數(shù)去掉。

另外,怎么樣才能學(xué)好python呢?我把python基礎(chǔ)教程看了,還是不會用到實(shí)際問題中,哎!

論壇徽章:
4
白羊座
日期:2013-11-05 10:26:09冥斗士
日期:2015-11-17 14:19:55白銀圣斗士
日期:2015-11-17 15:13:0815-16賽季CBA聯(lián)賽之新疆
日期:2016-04-01 09:10:58
2 [報告]
發(fā)表于 2015-01-08 09:16 |只看該作者
回復(fù) 1# yxycsgs
1. 代碼:
  1. import math

  2. mean = lambda x: sum(x) * 1.0 / len(x)
  3. variance = lambda x: map(lambda y: (y - mean(x)) ** 2, x)
  4. stdev = lambda x: math.sqrt(mean(variance(x)))

  5. def FilterData(data, minBar, maxBar):
  6.     return [item for item in data if (item >= minBar and item <= maxBar)]

  7. def ReadDataFromFile(name):
  8.     data = []
  9.     with open(name, "r") as handler:
  10.         for row in handler.readlines():
  11.             record = row.strip()
  12.             try:
  13.                 record = float(record)
  14.             except ValueError:
  15.                 record = 0
  16.             data.append(record)
  17.     return data

  18. def main():
  19.     data = ReadDataFromFile("")
  20.    
  21.     # Initialization filter
  22.     before = len(data)
  23.     m = mean(data)
  24.     x = stdev(data)
  25.     data = FilterData(data, m - 3 * x, m + 3 * x)
  26.     after = len(data)

  27.     # Filter loop
  28.     while before > after:
  29.         before = after
  30.         m = mean(data)
  31.         x = stdev(data)
  32.         data = FilterData(data, m - 3 * x, m + 3 * x)
  33.         after = len(data)

  34.     from pprint import pprint
  35.     pprint(data)
復(fù)制代碼
2. 用pythong解決問題:
解決問題的基礎(chǔ)是-〉正確的定義和分解問題。
從你的問題來看,至少定義問題還算相對比較清楚。
剩下的是分解問題,把一個大的問題分解成一系列的小問題,然后一個個小問題解決之后再組合到一起,一般情況下問題就解決了。
(當(dāng)然,也有不是一般情況的,比如:如果你的這個放數(shù)據(jù)的文件是至少幾個T的話,那求平均值、方差就需要使用到針對流式數(shù)據(jù)的求解方法,而不是現(xiàn)在的所有數(shù)據(jù)都在一個列表中的解決方法了。)

論壇徽章:
0
3 [報告]
發(fā)表于 2015-01-08 11:06 |只看該作者
麻煩閣下看一下Python求中位數(shù)那道題

   

論壇徽章:
0
4 [報告]
發(fā)表于 2015-01-08 12:56 |只看該作者
回復(fù) 2# icymirror

謝謝


   

論壇徽章:
26
2015亞冠之胡齊斯坦鋼鐵
日期:2015-06-25 21:40:202015亞冠之柏斯波利斯
日期:2015-08-31 17:03:192015亞冠之柏斯波利斯
日期:2015-11-07 13:10:00程序設(shè)計版塊每日發(fā)帖之星
日期:2015-11-10 06:20:00每日論壇發(fā)貼之星
日期:2015-11-10 06:20:00程序設(shè)計版塊每日發(fā)帖之星
日期:2015-11-26 06:20:00程序設(shè)計版塊每日發(fā)帖之星
日期:2015-12-02 06:20:00黃金圣斗士
日期:2015-12-07 17:57:4615-16賽季CBA聯(lián)賽之天津
日期:2015-12-23 18:34:14程序設(shè)計版塊每日發(fā)帖之星
日期:2016-01-02 06:20:00程序設(shè)計版塊每日發(fā)帖之星
日期:2016-01-06 06:20:00每日論壇發(fā)貼之星
日期:2016-01-06 06:20:00
5 [報告]
發(fā)表于 2015-05-20 21:35 |只看該作者
本帖最后由 substr函數(shù) 于 2015-05-20 23:02 編輯

一般情況
  1. #!/usr/bin/python2

  2. def Filter(a):
  3.     Mean = sum(a) / float(len(a))
  4.     Vari = map(lambda x: (Mean - x) ** 2, a)
  5.     Stdd = (sum(Vari) / float(len(Vari))) ** 0.5
  6.     x, z = Mean - 3 * Stdd, Mean + 3 * Stdd
  7.     b = filter(lambda y: x < y < z, a)
  8.     return a if a == b else Filter(b)

  9. # A = map(int, open('data.txt'))
  10. A = [11, 23, 6, 4, 12, 7, 9, 3, 5, 10, 25, 32, 77, 5, 3, 112]
  11. B = Filter(A)

  12. print A
  13. print B
復(fù)制代碼
您需要登錄后才可以回帖 登錄 | 注冊

本版積分規(guī)則 發(fā)表回復(fù)

  

北京盛拓優(yōu)訊信息技術(shù)有限公司. 版權(quán)所有 京ICP備16024965號-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報專區(qū)
中國互聯(lián)網(wǎng)協(xié)會會員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關(guān)心和支持過ChinaUnix的朋友們 轉(zhuǎn)載本站內(nèi)容請注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP