国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學(xué)院 > 開發(fā)設(shè)計 > 正文

算法訓(xùn)練 未名湖邊的煩惱 dp

2019-11-10 18:48:00
字體:
供稿:網(wǎng)友
問題描述  每年冬天,北大未名湖上都是滑冰的好地方。北大體育組準備了許多冰鞋,可是人太多了,每天下午收工后,常常一雙冰鞋都不剩。  每天早上,租鞋窗口都會排起長龍,假設(shè)有還鞋的m個,有需要租鞋的n個。現(xiàn)在的問題是,這些人有多少種排法,可以避免出現(xiàn)體育組沒有冰鞋可租的尷尬場面。(兩個同樣需求的人(比如都是租鞋或都是還鞋)交換位置是同一種排法)輸入格式  兩個整數(shù),表示m和n輸出格式  一個整數(shù),表示隊伍的排法的方案數(shù)。樣例輸入3 2樣例輸出5數(shù)據(jù)規(guī)模和約定  m,n∈[0,18]

  問題分析

思路:

dp[i][j]為所可能的排列總數(shù)  i 表示 i個還鞋的人數(shù)   j 表示 j個租鞋的人數(shù)

狀態(tài)轉(zhuǎn)移方程:

dp[i][0]=1;

dp[i][j]=dp[i-1][j]+dp[i][j-1];(i>=j)

其余為0;

我們知道:假設(shè)還鞋為m 租鞋為n

選擇時我們第一個必須為m,第二個我們可以選擇m也可以選擇n,第三個如果我們第二個選擇的為n則此時必須選擇m,如果我們第二步選擇了m的話,那上下的又回到了第二步的選擇,依次往下進行第四步第五步。。。

可的到如下關(guān)系: 把第dp[i-1][j],這時表示i-1個人還和j個人租時的所有排列情況,在所有排列情況下最后再排一個還鞋的人,就可以滿足i個人還鞋j個人租鞋的情況。

同理,在dp[i][j-1]時表示i個人還和j-1個人租時的所有排列情況,后面再排一個租鞋的人,得到dp[i][j]=dp[i-1][j]+dp[i][j-1],即i,j的所有排序情況、

#include<bits/stdc++.h>using namespace std;int dp[20][20];int main(){	int n,m,i,j;	scanf("%d %d",&m,&n);	dp[1][0]=1;	for(i=1;i<=18;i++)		for(j=1;j<=18;j++)		{			dp[i][j]=dp[i-1][j]+dp[i][j-1];		}		PRintf("%d/n",dp[m][n]);		return 0; } 


發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 郓城县| 吉隆县| 开原市| 玉山县| 东山县| 宣城市| 日土县| 扬州市| 武城县| 金沙县| 寿光市| 许昌县| 元江| 盘锦市| 师宗县| 宜州市| 隆回县| 梅州市| 山阳县| 石棉县| 靖安县| 顺平县| 屯昌县| 安阳市| 马公市| 凤山市| 金坛市| 鱼台县| 察隅县| 富蕴县| 涞源县| 尖扎县| 会宁县| 泽普县| 南木林县| 都安| 珠海市| 彩票| 东台市| 全州县| 甘德县|