動態(tài)規(guī)劃-飛機座位分配概率

package main;

/**
 * 有 n 位乘客即將登機案腺,飛機正好有 n 個座位。第一位乘客的票丟了趁舀,他隨便選了一個座位坐下。
 *
 * 剩下的乘客將會:
 *
 * 如果他們自己的座位還空著挽荡,就坐到自己的座位上母剥,
 *
 * 當(dāng)他們自己的座位被占用時,隨機選擇其他座位
 * 第 n 位乘客坐在自己的座位上的概率是多少这刷?
 *
 *  
 *
 * 示例 1:
 *
 * 輸入:n = 1
 * 輸出:1.00000
 * 解釋:第一個人只會坐在自己的位置上。
 * 示例 2:
 *
 * 輸入: n = 2
 * 輸出: 0.50000
 * 解釋:在第一個人選好座位坐下后娩井,第二個人坐在自己的座位上的概率是 0.5暇屋。
 *  
 *
 * 提示:
 *
 * 1 <= n <= 10^5
 *
 * 來源:力扣(LeetCode)
 * 鏈接:https://leetcode-cn.com/problems/airplane-seat-assignment-probability
 * 著作權(quán)歸領(lǐng)扣網(wǎng)絡(luò)所有。商業(yè)轉(zhuǎn)載請聯(lián)系官方授權(quán)洞辣,非商業(yè)轉(zhuǎn)載請注明出處咐刨。
 */
public class AirplaneSeatAssignmentProbability {

  public static void main(String[] args) {
    System.out.println("最后一個人坐自己位置概率為:"+ownSeat(4));
  }

  private static double ownSeat(int n) {
    //1昙衅、判斷是否滿足動態(tài)規(guī)劃
    //2、確定子問題參數(shù)定鸟、界定和計算順序
    //概率問題取反绒尊,求1-最后一個人位置被占用的概率。輸入n
    //3仔粥、初始值以及追蹤數(shù)組以及遞推函數(shù)
    if (n==1) return 1;
    if (n==2) return 0.5;
    double[] dp = new double[n];
    dp[0]=1;
    dp[1]=0.5;
    //找規(guī)律(求第n個人座位被占用概率)
    //n=3  a、1占用3蟹但,2占用2躯泰,3占用1 1/3 ok
    // b、1占用自己华糖,2占用自己麦向,3占用自己 1/3 no
    // c、1占用2客叉,2占用1诵竭,3占用自己 1/3*1/2 no
    // d、1占用2兼搏,2占用3卵慰,3占用1 1/3*1/2 ok
    // 占用概率 1-1/2=0.5

    //n=4  a、1占用4佛呻,2占用2裳朋,3占用3 4占用1 1/4 ok
    // b、1占用1吓著,2占用2鲤嫡,3占用3 4占用4 1/4 no
    // c、1占用2绑莺,2占用1暖眼,3占用3 4占用4 1/4*1/3 no
    // d、1占用2纺裁,2占用3诫肠,3占用1 4占用4 1/4*1/3*1/2 no
    // e、1占用2对扶,2占用4区赵,3占用3 4占用1 1/4*1/3 ok
    // f、1占用2浪南,2占用3笼才,3占用4 4占用1 1/4*1/3*1/2 ok
    // f、1占用3络凿,2占用2骡送,3占用1 4占用4 1/4*1/2 no
    // f昂羡、1占用3,2占用2摔踱,3占用4 4占用1 1/4*1/2 ok
    // 占用概率 1-1/4-1/4*1/3-1/4*1/3*1/2-1/4*1/2=0.5

    //結(jié)論:a虐先、一下子占用n 概率至少1/3 b、1若占用自己派敷,必然不會占用n c蛹批、1若占用其他位置,則子問題拋給其他人開始
    //1/n*(歷代相加)
    for (int i = 3; i <= n; i++) {
      dp[i-1]=1.0/i*(dp[i-2]*(i-1)+dp[i-2]);//化簡以后發(fā)現(xiàn)除1外一直0.5
    }

    return 1-dp[n-1];


  }

}

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末篮愉,一起剝皮案震驚了整個濱河市腐芍,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌试躏,老刑警劉巖猪勇,帶你破解...
    沈念sama閱讀 216,544評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異颠蕴,居然都是意外死亡泣刹,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,430評論 3 392
  • 文/潘曉璐 我一進店門犀被,熙熙樓的掌柜王于貴愁眉苦臉地迎上來椅您,“玉大人,你說我怎么就攤上這事寡键〗缶冢” “怎么了?”我有些...
    開封第一講書人閱讀 162,764評論 0 353
  • 文/不壞的土叔 我叫張陵昌腰,是天一觀的道長开伏。 經(jīng)常有香客問我,道長遭商,這世上最難降的妖魔是什么固灵? 我笑而不...
    開封第一講書人閱讀 58,193評論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮劫流,結(jié)果婚禮上巫玻,老公的妹妹穿的比我還像新娘。我一直安慰自己祠汇,他們只是感情好仍秤,可當(dāng)我...
    茶點故事閱讀 67,216評論 6 388
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著可很,像睡著了一般诗力。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上我抠,一...
    開封第一講書人閱讀 51,182評論 1 299
  • 那天苇本,我揣著相機與錄音袜茧,去河邊找鬼。 笑死瓣窄,一個胖子當(dāng)著我的面吹牛笛厦,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播俺夕,決...
    沈念sama閱讀 40,063評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼裳凸,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了劝贸?” 一聲冷哼從身側(cè)響起登舞,我...
    開封第一講書人閱讀 38,917評論 0 274
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎悬荣,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體疙剑,經(jīng)...
    沈念sama閱讀 45,329評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡氯迂,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,543評論 2 332
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了言缤。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片嚼蚀。...
    茶點故事閱讀 39,722評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖管挟,靈堂內(nèi)的尸體忽然破棺而出轿曙,到底是詐尸還是另有隱情,我是刑警寧澤僻孝,帶...
    沈念sama閱讀 35,425評論 5 343
  • 正文 年R本政府宣布导帝,位于F島的核電站,受9級特大地震影響穿铆,放射性物質(zhì)發(fā)生泄漏您单。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,019評論 3 326
  • 文/蒙蒙 一荞雏、第九天 我趴在偏房一處隱蔽的房頂上張望虐秦。 院中可真熱鬧,春花似錦凤优、人聲如沸悦陋。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,671評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽俺驶。三九已至,卻和暖如春棍辕,著一層夾襖步出監(jiān)牢的瞬間痒钝,已是汗流浹背秉颗。 一陣腳步聲響...
    開封第一講書人閱讀 32,825評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留送矩,地道東北人蚕甥。 一個月前我還...
    沈念sama閱讀 47,729評論 2 368
  • 正文 我出身青樓,卻偏偏與公主長得像栋荸,于是被迫代替她去往敵國和親菇怀。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,614評論 2 353