K好数(动态规划)
来源:互联网 发布:淘宝助理找不到图片 编辑:程序博客网 时间:2024/05/19 02:03
问题描述
如果一个自然数N的K进制表示中任意的相邻的两位都不是相邻的数字,那么我们就说这个数是K好数。求L位K进制数中K好数的数目。例如K = 4,L = 2的时候,所有K好数为11、13、20、22、30、31、33 共7个。由于这个数目很大,请你输出它对1000000007取模后的值。
输入格式
输入包含两个正整数,K和L。
输出格式
输出一个整数,表示答案对1000000007取模后的值。
样例输入
4 2
样例输出
7
数据规模与约定
对于30%的数据,KL <= 106;
对于50%的数据,K <= 16, L <= 10;
对于100%的数据,1 <= K,L <= 100。
思路:用kNumber[i][j]表示当位数为 i 时候 最后以为是 j 的 k好数个数,最后一位的前一位只要不是 j-1 j+1 就都可以 。
int main(){ /*数组a[i][j]表示第i位放置数字j的时候k好数的数量, 比如,放第3位的时候会用到放第二位的时候的结果,放第二位时又有很多可能, 所以得把每一种加起来。*/ int k = 0; int l = 0; int sum = 0; cin>>k; cout<<endl; cin>>l; cout<<endk; int kNumber[111][111]={0}; //先是只有一位的情况 for(int i = 0;i<k;i++) kNumber[1][i] = 1; //开始分析两位和更多位 for(int i = 2; i < l ;i++) for(int j = 0; j <k ;j++) for(int u = 0 ;u<k;u++){ if(u!=j-1 && u!=j+1){ kNumber[i][j] = kNumer[i][j] + kNumbwe[i-1][u]; kNumber[i][j] = kNumber[i][j] % 1000000007; } } for(int u=1;u<k;u++){ sum+=kNumber[l][u]; sum%=1000000007; } printf("%d",sum); return 0;}
阅读全文
0 0
- 蓝桥杯 K好数(动态规划)
- (一)K好数 动态规划
- 动态规划 (k好数)
- K好数(动态规划)
- k好数(动态规划)
- 动态规划之K好数(蓝桥杯ALGO-3)
- 算法训练 K好数 (动态规划)
- 蓝桥杯 算法训练 K好数 (动态规划)
- 蓝桥——k好数(动态规划)
- 蓝桥杯 K好数 算法训练 (动态规划DP)
- k好数 noip 动态规划
- 蓝桥杯 k好数 动态规划
- 蓝桥杯 ALGO-3 算法训练 K好数 (动态规划 DP)
- 动态规划之最大k乘积,编辑距离,k好数,节点选择,背包问题
- 动态规划 k好数 顽皮猫为你一边讲解一边写代码
- K好数(DP)
- k好数 (蓝桥杯)
- 长沙理工大学第十二届ACM大赛 K 大家一起来数二叉树吧 (动态规划)
- POI实现对Excel表格的操作一之导包与例子
- 数据结构:图的存储结构之邻接表
- [Linux操作系统]Ubuntu12.04开发环境搭建
- 词法分析中的 贪心算法
- JDK的安装及环境变量的配置
- K好数(动态规划)
- Java中的四种引用介绍和使用场景
- Kaggle学习之Machine Learning from Disaster(2) -SVM
- linux下安装texlive及中文环境配置,及texmaker安装
- 两个栈实现一个队列
- HDU 6118 度度熊的交易计划 (最小费用流变形)
- 播放assets文件里视频文件的问题
- Unity3d-NGUI的原理机制:深入剖析UIPanel,UIWidget,UIDrawCall底层原理
- UVa 100|The 3n+1 Problem|暴力|坑点多