ゲート

分析:这题过的人好多,然后大家好像是用矩阵过的(((φ(◎ロ◎;)φ)))。我自己是推公式的。

对于任意的N有这个式子∑Ni=2((iN)∗∑i/2j=0(2∗ji)∗2N−i)+2N, 就是先从里面选偶数个涂成两个指定的颜色,再在选出的里面选定涂某种颜色,选剩下的在剩下的两种颜色里任选。注意两种指定颜色都不选是特殊情况。式子化简下来是22N−2+2N−1。

代码:

  1. /*****************************************************/
  2. //#pragma comment(linker, "/STACK:1024000000,1024000000")
  3. #include <map>
  4. #include <set>
  5. #include <ctime>
  6. #include <stack>
  7. #include <queue>
  8. #include <cmath>
  9. #include <string>
  10. #include <vector>
  11. #include <cstdio>
  12. #include <cctype>
  13. #include <cstring>
  14. #include <sstream>
  15. #include <cstdlib>
  16. #include <iostream>
  17. #include <algorithm>
  18. using namespace std;
  19. #define offcin ios::sync_with_stdio(false)
  20. #define sigma_size 26
  21. #define lson l,m,v<<1
  22. #define rson m+1,r,v<<1|1
  23. #define slch v<<1
  24. #define srch v<<1|1
  25. #define sgetmid int m = (l+r)>>1
  26. #define LL long long
  27. #define ull unsigned long long
  28. #define mem(x,v) memset(x,v,sizeof(x))
  29. #define lowbit(x) (x&-x)
  30. #define bits(a) __builtin_popcount(a)
  31. #define mk make_pair
  32. #define pb push_back
  33. #define fi first
  34. #define se second
  35. const int INF = 0x3f3f3f3f;
  36. const LL INFF = 1e18;
  37. const double pi = acos(-1.0);
  38. const double inf = 1e18;
  39. const double eps = 1e-9;
  40. const LL mod = 10007;
  41. const int maxmat = 10;
  42. const ull BASE = 31;
  43. /*****************************************************/
  44. LL qpow(LL a, LL b) {
  45. LL res = 1;
  46. while (b) {
  47. if (b & 1) res = a * res % mod;
  48. b >>= 1;
  49. a = a * a % mod;
  50. }
  51. return res;
  52. }
  53. int main(int argc, char const *argv[]) {
  54. int T;
  55. cin>>T;
  56. while (T --) {
  57. int N;
  58. scanf("%d", &N);
  59. LL res = (qpow(2, 2 * N - 2) + qpow(2, N - 1)) % mod;
  60. printf("%lld\n", res);
  61. }
  62. return 0;
  63. }

poj 3734 Blocks的更多相关文章

  1. [POJ 3734] Blocks (矩阵高速幂、组合数学)

    Blocks Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 3997   Accepted: 1775 Descriptio ...

  2. POJ 3734 Blocks (矩阵快速幂)

    题目链接 Description Panda has received an assignment of painting a line of blocks. Since Panda is such ...

  3. poj 3734 Blocks 快速幂+费马小定理+组合数学

    题目链接 题意:有一排砖,可以染红蓝绿黄四种不同的颜色,要求红和绿两种颜色砖的个数都是偶数,问一共有多少种方案,结果对10007取余. 题解:刚看这道题第一感觉是组合数学,正向推了一会还没等推出来队友 ...

  4. POJ 3734 Blocks(矩阵快速幂+矩阵递推式)

    题意:个n个方块涂色, 只能涂红黄蓝绿四种颜色,求最终红色和绿色都为偶数的方案数. 该题我们可以想到一个递推式 .   设a[i]表示到第i个方块为止红绿是偶数的方案数, b[i]为红绿恰有一个是偶数 ...

  5. POJ 3734 Blocks (线性递推)

    定义ai表示红色和绿色方块中方块数为偶数的颜色有i个,i = 0,1,2. aij表示刷到第j个方块时的方案数,这是一个线性递推关系. 可以构造递推矩阵A,用矩阵快速幂求解. /*********** ...

  6. poj 3734 Blocks【指数型生成函数】

    指数型生成函数,推一推可得: \[ (1+\frac{x^1}{1!}+\frac{x^2}{2!}+\frac{x^3}{3!}+...)^2+(1+\frac{x^2}{2!}+\frac{x^4 ...

  7. POJ 3734 Blocks 矩阵递推

    POJ3734 比较简单的递推题目,只需要记录当前两种颜色均为偶数, 只有一种颜色为偶数 两种颜色都为奇数 三个数量即可,递推方程相信大家可以导出. 最后来个快速幂加速即可. #include< ...

  8. poj 1390 Blocks

    poj 1390 Blocks 题意 一排带有颜色的砖块,每一个可以消除相同颜色的砖块,,每一次可以到块数k的平方分数.问怎么消能使分数最大.. 题解 此题在徐源盛<对一类动态规划问题的研究&g ...

  9. POJ 1390 Blocks(记忆化搜索+dp)

    POJ 1390 Blocks 砌块 时限:5000 MS   内存限制:65536K 提交材料共计: 6204   接受: 2563 描述 你们中的一些人可能玩过一个叫做“积木”的游戏.一行有n个块 ...

随机推荐

  1. ubuntu14.04设置静态ip

    1. 找到文件并作如下修改: sudo vim /etc/network/interfaces 修改如下部分: auto eth0 iface eth0 inet static address 192 ...

  2. 关于yuv格式

    首先,内存分布        1:YUV420          (1):I420:              YYYYYYYY UU VV    =>YUV420P          (2): ...

  3. 关于 K米 —— 的案例分析

    第一部分 调研,评测 评测 下载并使用,描述最简单直观的个人第一次上手体验. 我觉得ktv遥控软件设计的很好,给我带来了很多方便,点歌也不用那么麻烦了跑到台子那里点,调各种音量灯光也是,所以第一次上手 ...

  4. 《利用python进行数据分析》读书笔记--第八章 绘图和可视化

    http://www.cnblogs.com/batteryhp/p/5025772.html python有许多可视化工具,本书主要讲解matplotlib.matplotlib是用于创建出版质量图 ...

  5. Mac OS Terminal 几个快捷键

    在Mac系统中几个键位组合可以使Terminal的操作更加灵活方便. 1.将光标移动到行首:ctrl + a 2.将光标移动到行尾:ctrl + e 3.清除屏幕:            ctrl + ...

  6. django之DB操作

    先来区分一下什么是一对一.多对多 一对一:子表从母表中选出一条数据一一对应,母表中选出来一条就少一条,子表不可以再选择母表中已被选择的那条数据: 一对多:子表从母表中选出一条数据一一对应,但母表的这条 ...

  7. Activty四种启动模式

    Activty启动提供了四种启动模式.launchMode: standard:每次启动新的活动窗口(new操作) singleTop:如果在栈顶是目标活动,则直接打开.否则开启新的活动窗口(new) ...

  8. php数据类型及转换

  9. 我的Markdown笔记

    一片简单的Markdown笔记,共8项,基本上满足Markdown文档的编写(表格不建议用Markdown),每项上半部分是源码,下半部分是效果图片. 标题 段落 列表 强调 分割线 代码 连接 图片 ...

  10. Log4net(1):配置的简单说明

    基础代码下载地址:https://github.com/zhangsai521314/StudyLog4net 1:按日期分隔日志 <configSections> <section ...