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

首頁 > 學院 > 開發(fā)設計 > 正文

藍橋杯 k好數(shù) 動態(tài)規(guī)劃

2019-11-11 01:38:11
字體:
供稿:網(wǎng)友
問題描述

如果一個自然數(shù)N的K進制表示中任意的相鄰的兩位都不是相鄰的數(shù)字,那么我們就說這個數(shù)是K好數(shù)。求L位K進制數(shù)中K好數(shù)的數(shù)目。例如K = 4,L = 2的時候,所有K好數(shù)為11、13、20、22、30、31、33 共7個。由于這個數(shù)目很大,請你輸出它對1000000007取模后的值。

輸入格式

輸入包含兩個正整數(shù),K和L。

輸出格式輸出一個整數(shù),表示答案對1000000007取模后的值。樣例輸入4 2樣例輸出7數(shù)據(jù)規(guī)模與約定

對于30%的數(shù)據(jù),KL <= 106;

對于50%的數(shù)據(jù),K <= 16, L <= 10;

對于100%的數(shù)據(jù),1 <= K,L <= 100。

k好數(shù)思路:要得到所有的L位K進制數(shù)的k好數(shù),我們需要先得到L-1位K進制數(shù)的k好數(shù),再將其中第L位與第L-1位相鄰的數(shù)去掉即可。(子問題

如果理解了上面那句話,那么我們只需要從1位開始遞推到L位的K進制數(shù)即可。

定義一個二維數(shù)組dp[i][j],其中 i表示位數(shù) j表示第一位數(shù)

即求出1位K進制數(shù)的k好數(shù)個數(shù),dp[1][j],求出2位K進制數(shù)的k好數(shù)個數(shù) dp[2][j],如此遞推下去直到L位,

再將保存L位開頭從1到K-1的K進制的k好數(shù)相加

AC代碼片段如下:

結合代碼更好理解一點

 #include<iostream>#include<algorithm>#include<memory.h>using namespace std;#define mod 1000000007  typedef long long ll;ll dp[110][110];   //dp[i][j] 表示 i 位數(shù) 且 j為第一位的k好數(shù)個數(shù)int k;				//k進制 int l;  			//l位數(shù) int main(){	ll sum=0;				//總計 	cin>>k>>l;	memset(dp,0,sizeof(dp));	for(int j=0;j<k;j++){			dp[1][j] =1;		//1位數(shù)的K好數(shù)    	}	for(int i=2;i<=l;i++){  		//從2位數(shù)到l位數(shù),動態(tài)規(guī)劃 		for(int j=0;j<k;j++){		//第一位數(shù)為j 			for(int f=0;f<k;f++){	//第二位數(shù)為f 				if(f+1!=j && f-1!=j){ //不是相鄰的數(shù)					dp[i][j] += dp[i-1][f];					dp[i][j] %= mod; 				} 			} 		} 	}	for(int j=1;j<k;j++){			//	去掉第一位為0的k好數(shù) 		sum += dp[l][j] ;		sum %= mod;	} 	cout<<sum;	return 0;}


發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 上饶县| 资溪县| 山东省| 石嘴山市| 衢州市| 通渭县| 克拉玛依市| 淅川县| 无棣县| 阳谷县| 时尚| 岑溪市| 高雄市| 黄山市| 商南县| 嘉黎县| 永康市| 长乐市| 十堰市| 即墨市| 铁岭县| 芦溪县| 龙陵县| 云梦县| 常山县| 绥德县| 新津县| 永丰县| 南华县| 武乡县| 耿马| 攀枝花市| 牡丹江市| 图片| 大安市| 吴川市| 涪陵区| 九龙坡区| 四会市| 厦门市| 渭南市|