HDU 4352 XHXJ's LIS
来源:互联网 发布:淘宝申请退货几天到账 编辑:程序博客网 时间:2024/06/05 15:24
题目分析
这道题前面说了一堆废话,不过这道题还是很有水准的,不愧是多校的题目。这道题就是让你求给定2个数字,让你求这2个数字之间的有多少个数字满足数字的每一位上的数组成的最长递增子序列为K。看这道题就满头包,不知道怎么构建状态,看了网上的代码,才发现原来要讲构成的递增子序列作为状态存下来,真是神奇呀!说好的数位dp,瞬间变成了数位dp加动规。然后就可以按照求单调递增子序列的n*logn的方法处理了,具体看代码。
#include <cstdio>#include <cstring>#include <iostream>#include <algorithm>using namespace std;typedef long long LL;LL L,R,K,dp[20][1<<10][12],bit[20];int sum(int x){ //找出递增子序列的长度,其实也就是2进制中1的个数 int cnt = 0; while(x){ if(x&1) cnt++; x >>= 1; } return cnt;}int Replace(int x,int s){ //这里用的不是二分,只是只有1~9这9个数,直接枚举找到存下来即可 for(int i = x; i <= 9; i++) if(s & (1<<i)) return (s^(1<<i))|(1<<x); return s|(1<<x);}LL dfs(int pos, int status, int flag, int limit){ if(pos < 1) return sum(status)==K; if(!limit && dp[pos][status][K] != -1) return dp[pos][status][K]; int len = limit?bit[pos]:9; LL ret = 0; for(int i = 0; i <= len; i++){ ret += dfs(pos-1, (flag&&i==0)?0:Replace(i,status), flag&&(i==0), limit&&i==len); } if(!limit) dp[pos][status][K] = ret; return ret;}LL solve(LL n){ int len = 0; while(n){ bit[++len] = n%10; n /= 10; } return dfs(len, 0, 1, 1);}int main(){ int T; scanf("%d", &T); memset(dp, -1, sizeof(dp)); for(int kase = 1; kase <= T; kase++){ scanf("%I64d %I64d %I64d", &L, &R, &K); printf("Case #%d: %I64d\n", kase, solve(R) - solve(L-1)); } return 0;
0 0
- HDU 4352 XHXJ's LIS
- HDU-4352 XHXJ's LIS
- hdu 4352 XHXJ's LIS
- HDU 4352 XHXJ's LIS
- HDU 4352 XHXJ's LIS
- hdu 4352 XHXJ's LIS
- HDU 4352 XHXJ's LIS
- 【HDU】4352 XHXJ's LIS 数位DP
- 【数位DP】【hdu 4352】XHXJ's LIS
- HDU 4352 XHXJ's LIS 数位dp
- HDU 4352 XHXJ's LIS(数位DP)
- hdu 4352 XHXJ's LIS(数位dp)
- HDU 4352 XHXJ's LIS【数位DP】
- hdu 4352 XHXJ's LIS(LIS+数位DP,5级)
- 数位dp+LIS+状态压缩-hdu-4352-XHXJ's LIS
- HDU 4352 XHXJ's LIS 数位dp+lis
- HDOJ 4352 XHXJ's LIS
- hdu 4352 XHXJ's LIS --- 数位dp 状态压缩
- 用递归函数和栈操作逆序一个栈
- 接口和抽象类区别
- Timus 1104 Don’t Ask Woman about Her Age
- UVALive 2889 Palindrome Numbers
- GP学习(十)-Mosaic raster datasets to a file raster format
- HDU 4352 XHXJ's LIS
- C#和JAVA利用BASE64实现图片编码解码
- 容斥原理 —— 求1~n有多少个数与k互质(二进制算法详细解释&模板)
- CodeForces 1B
- Java wait(long arg)方法的使用
- golang substring方法的几种实现
- NYOJ263精挑细选
- Java调用C++ API完整示例(dll)
- 【杭电2124】Repair the Wall