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]个字符可以变成回文串,可以利用动态规划的思想,求解 状态转化方程: ...
随机推荐
- Design and Implementation of Global Path Planning System for Unmanned Surface Vehicle among Multiple Task Points
Design and Implementation of Global Path Planning System for Unmanned Surface Vehicle among Multiple ...
- bootstrap中模态框、模态框的属性
工作中有需要用到模态框的可以看看 <div class="modal fade" id="userModal" tabindex="-1&quo ...
- webpack-dev-middleware插件的使用
我们在使用webpack 编译文件时,每次改动文件都要去重新编译,是不是很麻烦,这时候我们就用到了webpack-dev-middleware 插件,该插件对更改的文件进行监控,编译, 一般和 web ...
- RandomUserAgentMiddleware练习
# 请求头添加随机user-agent class RandomUserAgentMiddleware(object): def __init__(self, agents): self.agent ...
- 14 - Log日志
LOG https://www.cnblogs.com/yyds/p/6901864.html logging logging模块提供模块级别的函数记录日志 包括四大组件 1.日志相关概念 日志的级别 ...
- Webpack4 学习笔记三 ES6+语法降级为ES5
前言 此内容是个人学习笔记,以便日后翻阅.非教程,如有错误还请指出 Webpack 将es6.es7语法降级为es5 需要通过 babel JavaScript编译器. 安装: npm i babel ...
- Golang反射机制
Go反射机制:在编译不知道类型的情况下,可更新变量.在运行时查看值.调用方法以及直接对它们的布局进行操作. 为什么使用反射 有时需要封装统一接口对不同类型数据做处理,而这些类型可能无法共享同一个接口, ...
- Python学习之三级菜单
Python经典练习题 - 三级菜单 需求: 可依次选择进入各子菜单 可从任意一层往回退到上一层 可从任意一层退出程序 示例代码: # -*- coding: utf-8 -*- menu = { ' ...
- 转:Java后端面试自我学习
引自:https://www.cnblogs.com/JavaArchitect/p/10011253.html 最近面试java后端开发的感受:如果就以平时项目经验来面试,通过估计很难——再论面试前 ...
- 基本数据类型补充,set集合,深浅拷贝等
1.join:将字符串,列表,用指定的字符连接,也可以用空去连接,这样就可以把列表变成str ll = ["wang","jian","wei&quo ...