DP+快速矩阵幂。注意base矩阵的初始化,不难。

 /* 5564 */
#include <iostream>
#include <string>
#include <map>
#include <queue>
#include <set>
#include <stack>
#include <vector>
#include <deque>
#include <algorithm>
#include <cstdio>
#include <cmath>
#include <ctime>
#include <cstring>
#include <climits>
#include <cctype>
#include <cassert>
#include <functional>
#include <iterator>
#include <iomanip>
using namespace std;
//#pragma comment(linker,"/STACK:102400000,1024000") #define sti set<int>
#define stpii set<pair<int, int> >
#define mpii map<int,int>
#define vi vector<int>
#define pii pair<int,int>
#define vpii vector<pair<int,int> >
#define rep(i, a, n) for (int i=a;i<n;++i)
#define per(i, a, n) for (int i=n-1;i>=a;--i)
#define clr clear
#define pb push_back
#define mp make_pair
#define fir first
#define sec second
#define all(x) (x).begin(),(x).end()
#define SZ(x) ((int)(x).size())
#define lson l, mid, rt<<1
#define rson mid+1, r, rt<<1|1 const int mod = 1e9+;
const int maxn = ;
int ID[maxn][maxn];
int n; typedef struct mat_t {
__int64 m[maxn][maxn]; mat_t() {
memset(m, , sizeof(m));
} void init() {
memset(m, , sizeof(m));
} void print() {
rep(i, , n) {
rep(j, , n) {
printf("%I64d ", m[i][j]);
}
putchar('\n');
}
}
} mat_t; mat_t matMult(mat_t& a, mat_t& b) {
mat_t c; rep(i, , n)
rep(j, , n)
rep(k, , n)
c.m[i][j] = (c.m[i][j] + a.m[i][k]*b.m[k][j]%mod)%mod; return c;
} mat_t matPow(mat_t a, int m) {
mat_t ret; rep(i, , n)
ret.m[i][i] = ;
while (m) {
if (m & )
ret = matMult(ret, a);
a = matMult(a, a);
m >>= ;
} return ret;
} mat_t e;
mat_t base; void init(int s) {
// first column is one
// first row is zero(accept first one)
rep(j, , n) {
e.m[][j] = ;
if (j% == )
e.m[j][] = ;
else
e.m[j][] = ;
}
e.m[][] = ; rep(i, , ) {
rep(j, , ) {
rep(ii, , ) {
int jj = (*j+ii)%;
int id = ID[i][j];
int id_ = ID[ii][jj];
if (i+ii == s)
e.m[id][id_] = ;
else
e.m[id][id_] = ;
}
}
} #ifndef ONLINE_JUDGE
// e.print();
#endif
} void init_base() {
int cnt = ;
n = *+; rep(i, , )
rep(j, , )
ID[i][j] = cnt++;
rep(i, , )
base.m[][ID[i][i%]] = ;
} __int64 cal(int len) {
if (len == )
return ; __int64 ret = ;
mat_t res = matPow(e, len); rep(i, , n)
ret = (ret + base.m[][i]*res.m[i][]%mod)%mod;
return ret;
} int main() {
ios::sync_with_stdio(false);
#ifndef ONLINE_JUDGE
freopen("data.in", "r", stdin);
freopen("data.out", "w", stdout);
#endif int t;
int l, r, s;
__int64 nl, nr, ans; init_base();
scanf("%d", &t);
while (t--) {
scanf("%d %d %d", &l, &r, &s);
init(s);
nl = cal(l-);
nr = cal(r);
ans = (nr-nl+mod) % mod;
#ifndef ONLINE_JUDGE
printf("nl = %I64d, nr = %I64d\n", nl, nr);
#endif
printf("%I64d\n", ans);
} #ifndef ONLINE_JUDGE
printf("time = %d.\n", (int)clock());
#endif return ;
}

【HDOJ】5564 Clarke and digits的更多相关文章

  1. 【LeetCode】738. Monotone Increasing Digits 解题报告(Python)

    [LeetCode]738. Monotone Increasing Digits 解题报告(Python) 标签(空格分隔): LeetCode 作者: 负雪明烛 id: fuxuemingzhu ...

  2. 【LeetCode】402. Remove K Digits 解题报告(Python)

    [LeetCode]402. Remove K Digits 解题报告(Python) 标签(空格分隔): LeetCode 作者: 负雪明烛 id: fuxuemingzhu 个人博客: http: ...

  3. 【LeetCode】423. Reconstruct Original Digits from English 解题报告(Python)

    [LeetCode]423. Reconstruct Original Digits from English 解题报告(Python) 标签: LeetCode 题目地址:https://leetc ...

  4. hdu 5564 Clarke and digits 矩阵快速幂优化数位dp

    Clarke and digits Time Limit: 5000/3000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others ...

  5. 【HDOJ】4333 Revolving Digits

    扩展KMP基础题目. /* 4333 */ #include <iostream> #include <sstream> #include <string> #in ...

  6. 【HDOJ】4729 An Easy Problem for Elfness

    其实是求树上的路径间的数据第K大的题目.果断主席树 + LCA.初始流量是这条路径上的最小值.若a<=b,显然直接为s->t建立pipe可以使流量最优:否则,对[0, 10**4]二分得到 ...

  7. 【HDOJ】5632 Rikka with Array

    1. 题目描述$A[i]$表示二级制表示的$i$的数字之和.求$1 \le i < j \le n$并且$A[i]>A[j]$的$(i,j)$的总对数. 2. 基本思路$n \le 10^ ...

  8. 【HDOJ】4343 Interval query

    最大不相交集合的数量.思路是dp[i][j]表示已经有i个不相交集合下一个不相交集合的最右边界.离散化后,通过贪心解. /* 4343 */ #include <iostream> #in ...

  9. 【HDOJ】4341 Gold miner

    分组01背包.在一条直线上的点归为一组. /* 4341 */ #include <iostream> #include <sstream> #include <stri ...

随机推荐

  1. 05顺序队列_Queue--(栈与队列)

    #include "stdio.h" #include "stdlib.h" #include "io.h" #include " ...

  2. 折腾ghost。。。

    1.启动 NODE_ENV=production node index.js 如果出现启动不了的情况,在该命令加sudo sudo NODE_ENV=production node index.js ...

  3. centos下 forever: 让nodejs应用后台执行

    在LINUX中我们可以使用这种简单的方式让node.js在后台运行: nohup node your_app.js & forever可以让我们做得更好,并且可以跨平台的在windows和Li ...

  4. myeclipse-8.6.0下载

    myeclipse老版本不分32位和64位,欢迎大家下载使用! 链接:http://pan.baidu.com/s/1dEJCxcl 密码:z1ga

  5. HDU 1087 Super Jumping! Jumping! Jumping!(动态规划)

    Super Jumping! Jumping! Jumping! Problem Description Nowadays, a kind of chess game called “Super Ju ...

  6. Poj/OpenJudge 1000 A+b Problem C/C++/Java

    1.题意翻译:        输入两个整数a,b (0<=a,b<=10),计算a+b的值并输出.       其中还提到输出不能有多余的内容,即不能加多空格符号等内容,不然会报Wrong ...

  7. Weui 微信网站开发样式插件使用教程

    微信的网页样式正式发布了,搜了一下,正式引入了乐学一百微信端的项目中. <div class="weui_grids"> <a href="javasc ...

  8. 点击按钮文字变成input框,点击保存变成文字

    <!DOCTYPE html><html lang="en"> <head> <meta http-equiv="Content ...

  9. Android开发系列之AChartEngine

    Android图表控件的开发 曾经开发过一个小程序,在Android电视机上面开发一个APP,用于显示一些统计图表的信息.最后找来找去基于Android Native开发有AChartEngine现成 ...

  10. API获得ip,JS获得IP地理信息

      <script type="text/javascript" src="http://zone.xmp.kankan.xunlei.com/find_area_ ...