java 板


LINE

之前好像有看過類似的問題...可以參考一下。 文章網址如下: http://www.javaworld.com.tw/jute/post/view?bid=29&id=141413&sty=1 如果眼睛不嫌累的話,就看以下的程式碼吧。 _________________________________________________________________ package test; public class DiscreteProcessor { protected int X1; protected int X2; protected int[] arr; /** * 設定曲線方程式跟區間(x1,x2) * @param fomula * @param X1 * @param X2 */ public void init(CurveFomula fomula,int X1,int X2) { this.X1 = X1; this.X2 = X2; arr = new int[X2-X1]; for (int i = 0, j = arr.length; i < j; i++) { int X = X1 + i;// 現在的X值 arr[i] = fomula.excute(X); // System.out.println("arr[" +i+ "]" + arr[i]); } } /** * 從X1開始,到X2結束,求算曲線積分值, * @return */ public long sigmaDiscrete() { long SUM = 0; for (int i = 0, j = arr.length; i < j; i++) SUM += arr[i]; return SUM; } /** * 取得符合該Fomula的整數離散數列,從X1開始,到X2結束 * @return */ public int[] getDiscreteSamples() { return arr; } /** * @param args */ public static void main(String[] args) { int x1 = 1; int x2 = 1001; int length = x2-x1; Ah_taiCurveFomula fomula1 = new Ah_taiCurveFomula(); DiscreteProcessor processor = new DiscreteProcessor(); processor.init(fomula1,x1,x2); int[] testData = new int[length];//測試統計結果 for (int i = 0, j = 1000000; i < j; i++) { int pickData = diceValue(processor.sigmaDiscrete(), processor.getDiscreteSamples());//多骰幾次,統計一下 testData[pickData]++; } for (int i = 0, j = length; i < j; i++) {// 試看看列印出來答案跟權陣的比例一不一樣? // System.out.println("ans[" + i + "]" + testData[i]); System.out.println(testData[i]); } } /** * Random出來一個參數,然後看他落在哪個權陣區間...燈燈燈,答案出來瞭 * * @param q * @param weightArr * @return */ public static int diceValue(long SUM, int[] weightArr) { double total = Math.random() * SUM; int temp = 0; for (int i = 0, j = weightArr.length; i < j; i++) { temp += weightArr[i]; if (total <= temp) { return i; } } return -1;// an fatal Error!!! } } interface CurveFomula { /** * Y = f(x),輸入X,求Y,直接叫f of x太難聽. * @param X * @return f(X) */ int excute(int X); } /** * @author Ian *一個CurveFomula的實作,你也可以實作自己的 */ class MyCurveFomula implements CurveFomula { public int excute(int X) { return (int) Math.floor(700000 / X); } } /** * * @author Ian *一個CurveFomula的實作,用你給的方程式 */ class Ah_taiCurveFomula implements CurveFomula { /** * y=1/400 * e ^ ((-1/400)*x) * */ public int excute(int X) { return (int) Math.floor(Math.pow(Math.E,((-1d/400d)*X))*100000d/400d) ; } } ___________________________________________________________________________ 原理是這樣的: 你先開一個地址存放陣列addressArr: int[] addressArr = new int[]{1,2,3}; 然後開一個權重存放矩陣weightArr: int[] weightArr = new int[]{9,5,1}; 再來,亂數產生器產生從 [min ~ SUM(min~max)] 中的任一亂數X。 int address = -1; int sum = 0; for(int i=0;i<weightArr.length;i++) { sum += weightArr[i]; if(X<sum) { address = i; break; } } 這時候,addressArr[X]就是你要的答案。 雖然JAVA沒有指標,你還是可以開陣列去模擬這樣的概念。 隨機產生出來的大量亂數在統計上就會服從你給的曲線分佈。 不曉得能不能解決問題? PS:to 版主,kkcity跟這裏好像已經Async了... -- --



※ 發信站: 批踢踢實業坊(ptt.cc)
◆ From: 210.85.116.116







like.gif 您可能會有興趣的文章
icon.png[問題/行為] 貓晚上進房間會不會有憋尿問題
icon.pngRe: [閒聊] 選了錯誤的女孩成為魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一張
icon.png[心得] EMS高領長版毛衣.墨小樓MC1002
icon.png[分享] 丹龍隔熱紙GE55+33+22
icon.png[問題] 清洗洗衣機
icon.png[尋物] 窗台下的空間
icon.png[閒聊] 双極の女神1 木魔爵
icon.png[售車] 新竹 1997 march 1297cc 白色 四門
icon.png[討論] 能從照片感受到攝影者心情嗎
icon.png[狂賀] 賀賀賀賀 賀!島村卯月!總選舉NO.1
icon.png[難過] 羨慕白皮膚的女生
icon.png閱讀文章
icon.png[黑特]
icon.png[問題] SBK S1安裝於安全帽位置
icon.png[分享] 舊woo100絕版開箱!!
icon.pngRe: [無言] 關於小包衛生紙
icon.png[開箱] E5-2683V3 RX480Strix 快睿C1 簡單測試
icon.png[心得] 蒼の海賊龍 地獄 執行者16PT
icon.png[售車] 1999年Virage iO 1.8EXi
icon.png[心得] 挑戰33 LV10 獅子座pt solo
icon.png[閒聊] 手把手教你不被桶之新手主購教學
icon.png[分享] Civic Type R 量產版官方照無預警流出
icon.png[售車] Golf 4 2.0 銀色 自排
icon.png[出售] Graco提籃汽座(有底座)2000元誠可議
icon.png[問題] 請問補牙材質掉了還能再補嗎?(台中半年內
icon.png[問題] 44th 單曲 生寫竟然都給重複的啊啊!
icon.png[心得] 華南紅卡/icash 核卡
icon.png[問題] 拔牙矯正這樣正常嗎
icon.png[贈送] 老莫高業 初業 102年版
icon.png[情報] 三大行動支付 本季掀戰火
icon.png[寶寶] 博客來Amos水蠟筆5/1特價五折
icon.pngRe: [心得] 新鮮人一些面試分享
icon.png[心得] 蒼の海賊龍 地獄 麒麟25PT
icon.pngRe: [閒聊] (君の名は。雷慎入) 君名二創漫畫翻譯
icon.pngRe: [閒聊] OGN中場影片:失蹤人口局 (英文字幕)
icon.png[問題] 台灣大哥大4G訊號差
icon.png[出售] [全國]全新千尋侘草LED燈, 水草

請輸入看板名稱,例如:Tech_Job站內搜尋

TOP