HDU 4669 Mutiples on a circle 动态规划
参考了官方题解给的方法:
对于处理循环,官方给了一种很巧妙的方法:
#include <cstdio>
#include <cstring>
#include <cstdlib> #define LL long long int const int MAXN = ;
const int MAXMOD = ; int N, K;
int dp[MAXN][MAXMOD];
int val[MAXN];
int fac[MAXN << ];
int len[]; void init()
{
for ( int i = ; i < ; ++i ) len[i] = ;
for ( int i = ; i < ; ++i ) len[i] = ;
for ( int i = ; i < ; ++i ) len[i] = ;
for ( int i = ; i < ; ++i ) len[i] = ;
return;
} void GetFac()
{
fac[] = ;
int lenn = (N << );
for ( int i = ; i < lenn; ++i )
fac[i] = ( fac[i - ] * ) % K;
return;
} int main()
{
//freopen( "1004.in", "r", stdin );
//freopen( "ss.out", "w", stdout );
init();
while ( ~scanf("%d%d", &N, &K ) )
{
for ( int i = ; i < N; ++i )
scanf( "%d", &val[i] );
GetFac(); val[N] = val[];
int sum = ;
int totL = ; //不要用memset,否则会超时
for ( int i = ; i <= N; ++i )
for ( int j = ; j <= K; ++j )
dp[i][j] = ; for ( int i = N; i > ; --i )
{
sum = ( val[i] * fac[totL] + sum ) % K;
totL += len[ val[i] ];
++dp[][sum];
} LL ans = dp[][];
for ( int i = ; i < N; ++i )
{
for ( int j = ; j < K; ++j )
dp[i][ ( j * fac[ len[ val[i] ] ] + val[i] ) % K ] += dp[i - ][j];
sum = ( sum * fac[ len[ val[i] ] ] + val[i] ) % K;
--dp[i][sum];
++dp[i][ val[i]%K ];
sum = ( ( sum - val[i] * fac[totL] ) % K + K ) % K;
ans += dp[i][];
} printf( "%I64d\n", ans );
}
return ;
}
HDU 4669 Mutiples on a circle 动态规划的更多相关文章
- HDU 4669 Mutiples on a circle (2013多校7 1004题)
Mutiples on a circle Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 65535/65535 K (Java/Oth ...
- HDU 4669 Mutiples on a circle 数位DP
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=4669 考察对取模的的理解深不深刻啊,当然还有状态的设计····设d[i][j]表示以第i个数结尾,余 ...
- HDU 4669 Mutiples on a circle(环状DP)
题目链接 这是最早看懂题意的一题,状态转移,挺好想..但是比赛时候,就是没有想到怎么去重,而且当时有些情况,也没注意到. 先预处理的dp[0]的情况,就是以p[0]为结尾的情况.之后D就行了,例如样例 ...
- HDU 4669 Mutiples on a circle (DP , 统计)
转载请注明出处,谢谢http://blog.csdn.net/ACM_cxlove?viewmode=contents by---cxlove 题意:给出一个环,每个点是一个数字,取一个子串,使 ...
- HDU 4669 Mutiples on a circle 不知道该归为哪一类。
题意:给你N个珠宝和一个K,每个珠宝上面都有数字,这个珠宝做成项链,把珠宝上的数字拼起来如果可以整除掉K,那么久说这个数字为wonderful value,问你有多少种方案可以组成WONDERFUL ...
- HDU 4665 Mutiples on a circle (圆环DP)
题意 N个数的圆环上有多少种方案可以使得选出来的一段数是K的倍数(N<=50000, K<=200, a[i]<=1000). 思路 多校第七场1004.圆上的DP--大脑太简单处理 ...
- hdu 4669 动态规划
思路:主要就是一个动态方程dp[now][(j*Exp[len[num[i]]]+num[i])%k]+=dp[pre][j];我用的是滚动数组.其实也就是dp[i][(j*Exp[len[num[i ...
- HDU-4669 Mutiples on a circle 环形DP
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4669 题意:给一串数字连乘一个环,求连续的子串中组成的新的数字能被K整除的个数. 首先容易想到用DP来 ...
- hdu 1159 Palindrome(回文串) 动态规划
题意:输入一个字符串,至少插入几个字符可以变成回文串(左右对称的字符串) 分析:f[x][y]代表x与y个字符间至少插入f[x][y]个字符可以变成回文串,可以利用动态规划的思想,求解 状态转化方程: ...
随机推荐
- iPad游戏 Calcculator: The Game 程序自动计算求解方法
今天在iPad上下了个小游戏,主要是一个计算器的界面,有开始值,目标值,限定步数,以及一些加减乘除,还有作者脑洞想出来的功能键,主要有左移,直接把一个数加到末尾,将其中的某个数改为另一个数等等..玩到 ...
- AngularJS 表达式中添加过滤器实例
过滤器可以通过一个管道字符(|)和一个过滤器添加到表达式中 历练实例: <!DOCTYPE html><html><head><meta http-equiv ...
- input的类型为number,限制输入的数字位数
<input type="text" maxlength="5" /> 效果ok,当 <input type="number& ...
- JavaSE 面试题总结
一. JavaSE 4 1. 面向对象的特征有哪些方面 4 2. String是最基本的数据类型吗? 4 3. super()与this()的区别? 4 4. JAVA的事件委托机制和垃圾回收机制 4 ...
- spring boot+log4j2快速使用(一)
log4j是Apache的一个开源项目,log4j2和log4j是一个作者,只不过log4j2是重新架构的一款日志组件,他抛弃了之前log4j的不足,以及吸取了优秀的logback的设计重新推出的一款 ...
- sqlite的sql常用语句(笔记)
1.复制一张表并重命名 比如已经创建好一个表 表名为"28165" 复制这个表. CREATE TABLE [33150] AS SELECT * FROM [28165] 2.根 ...
- tcl之控制流-break/continue
- PHP使用redis(一)
1,connect 描述:实例连接到一个Redis.参数:host: string,port: int返回值:BOOL 成功返回:TRUE;失败返回:FALSE <?php $redis = ...
- jQuery-laye插件实现 弹框编辑,异步验证,form验证提交
代码中用到了 jQuery的ajax异步处理,each()循环,submit()页面验证提交form表单,prepend()追加标签,laye插件的弹框效果(如有其它弹框效果可参考官网:http:// ...
- C# WPF使一个窗口挡在最前面,且不处理此窗口就不能点击其他窗口
模态框弹出就可以了.窗口用ShowDialog调用. 可以在子窗体里把WindowStartupLocation设置为CenterOwner, 让子窗体在MainWindow的中心位置显示