首页 > 代码库 > Sicily 1146:Lenny's Lucky Lotto(dp)
Sicily 1146:Lenny's Lucky Lotto(dp)
题意:给出N,M,问有多少个长度为N的整数序列,满足所有数都在[1,M]内,并且每一个数至少是前一个数的两倍。例如给出N=4, M=10, 则有4个长度为4的整数序列满足条件: [1, 2, 4, 8], [1, 2, 4, 9], [1, 2, 4, 10], [1, 2, 5, 10]
分析:可用动态规划解题,假设dp[i][j],代表满足以整数i为尾数,长度为j的序列的个数(其中每一个数至少是前一个数的两倍)。那么对于整数i,dp[i][j] 等于所有dp[k][j-1]的和,其中k满足:2*k <= i。计算出dp矩阵后,答案便是dp[i][N]的和(i = 1, 2, ... ,N)
#include <bits/stdc++.h> using namespace std; int main(int argc, char const *argv[]) { int T; int index = 0; cin >> T; while(T--){ int N, M; cin >> N >> M; long long dp[M+1][N+1]; memset(dp, 0, sizeof(dp)); for(int i = 1; i <= M; i++){ for(int j = 1; j <= N; j++){ if(j == 1)dp[i][j] = 1; else{ for(int k = 1; 2*k <= i; k++){ dp[i][j] += dp[k][j-1]; } } } } long long ans = 0; for(int i = 1; i <= M; i++){ ans += dp[i][N]; } printf("Case %d: n = %d, m = %d, # lists = %lld\n", ++index, N, M, ans); } return 0; }
Sicily 1146:Lenny's Lucky Lotto(dp)
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。