http://acm.hdu.edu.cn/showproblem.php?pid=6

分析:

这道题,全都是1e9,所以我们很容易想到“矩阵快速幂”。

假如说我们没有后面那个“向下取整”的东西,而将他看作一个常熟C

我们可以很轻松的得到矩阵幂的式子

然后呢,那个常熟C却会随着i变化

我们只需要整除分块,分别进行矩阵幂,这道题就解决了

  1. #include<bits/stdc++.h>
  2. using namespace std;
  3. #define re register int
  4. #define LL long long
  5. #define int long long
  6. const int mo = 1e9+7;
  7. typedef int arr[10][10];
  8. arr A, ans;
  9. void modi(arr y, arr x)
  10. {
  11. arr z; memset(z, 0, sizeof(z));
  12. for(re i=1;i<=3;++i)
  13. {
  14. for(re j=1;j<=3;++j)
  15. {
  16. for(re k=1;k<=3;++k)
  17. {
  18. z[i][j] = (z[i][j] + y[i][k]*x[k][j] % mo) % mo;
  19. }
  20. }
  21. }
  22. memcpy(y, z, sizeof(z));
  23. }
  24. int a, b, c, d, p, n, q;
  25. void Montgomery(int pp)
  26. {
  27. ans[1][3] = q % mo;
  28. memset(A, 0, sizeof(A));
  29. A[1][2]=c%mo; A[2][2]=d%mo; A[2][1]=A[3][2]=A[3][3]=1ll;
  30. while(pp)
  31. {
  32. if(pp&1) modi(ans, A);
  33. pp>>=1;
  34. modi(A,A);
  35. }
  36. }
  37. inline void work()
  38. {
  39. scanf("%lld%lld%lld%lld%lld%lld",&a,&b,&c,&d,&p,&n);
  40. if(n == 1) printf("%lld\n", a);
  41. else if(n == 2) printf("%lld\n", b);
  42. else
  43. {
  44. memset(ans, 0, sizeof(ans));
  45. ans[1][1]=a;
  46. ans[1][2]=b;
  47. for(re i=3;i<=n;)
  48. {
  49. q = p/i;
  50. int nt;
  51. if(q == 0) nt=n; else nt = min(n, p/q);
  52. Montgomery(nt-i+1);
  53. i=nt+1;
  54. }
  55. printf("%lld\n", ans[1][2] % mo);
  56. }
  57.  
  58. }
  59. signed main()
  60. {
  61. int T;scanf("%lld",&T);
  62. while(T--) work();
  63. }

made by kzsn

“向着风拥抱彩虹,勇敢的向前走”

“黎明的那道光,会越过黑暗”

“打破一切恐惧我能,找到答案” ----《你的答案》阿冗

热身训练1 Sequence的更多相关文章

  1. HDU6299-2018ACM暑假多校联合训练1002-Balanced Sequence

    这个题的题意是给你n个字符串,认定()是一种平衡的串,两个以上连续的()()也是一种平衡的串,如果一对括号里面包含一个平衡的串,这个括号也被算在这个平衡的串之内, 如(()(()))是一个长度为8的平 ...

  2. 数位dp & 热身训练7

    数位dp 数位dp是一种计数用的dp,一般就是要统计一段区间$[L,R]$内,满足一定条件的数的个数,或者各个数位的个数. 数位dp使得暴力枚举变为满足一定状态的记忆化,更加优秀. 数位dp常常会考虑 ...

  3. 热身训练4 Article

    Article 在这个学期即将结束时,DRD开始写他的最后一篇文章. DRD使用著名的Macrohard的软件World来写他的文章. 不幸的是,这个软件相当不稳定,它总是崩溃. DRD需要在他的文章 ...

  4. 热身训练4 Eighty seven

    Eighty seven 简要题意: n个卡片,其中第i个卡片的数值为$a[i]$.一共q次询问,每次询问将删去其中3个卡片(可能删除若干相同的卡片)后,问能否选出10个卡片,数值之和等于87. n≤ ...

  5. 热身训练2 The All-purpose Zero

    The All-purpose Zero 简要题意:  长度为n的数组,每个数字为S[i],$0$是一种很神奇的数字,你想要的,它都可以变! 问这个序列的最长上升子序列长度为多少? 分析: 我们将除了 ...

  6. 热身训练3 Palindrome

    Palindrome 简要题意:  我们有一个字符串S,字符串的长度不超过500000. 求满足S[i]=S[2n−i]=S[2n+i−2](1≤i≤n)(n≥2)的子串个数.  分析: 我们能通过简 ...

  7. 热身训练2 GCD

    题目描述 简要题意:  n个数字,a1,a2,...,an m次询问(l,r),每次询问需回答 1.gcd(al,al+1,al+2,...,ar);2.gcd(ax,ax+1,ax+2,...,ay ...

  8. 热身训练2 Another Meaning

    题目来源 简要题意: 众所周知,在许多情况下,一个词语有两种意思.比如"hehe",不仅意味着"hehe",还意味着"excuse me". ...

  9. 热身训练1 Calculator

    题目出处:Calculator 简要题意: 你有一个确定的函数,f(x)=+...*...^...,其中共有n个操作,从左到右依次计算. 共有m次询问,我们每次询问,1.会修改f(x)中的操作:2.输 ...

随机推荐

  1. npm 淘宝镜像与官方源 切换

    1.临时使用 npm --registry https://registry.npm.taobao.org install 包名 2.永久设置为淘宝镜像 npm config set registry ...

  2. Element UI:级联选择器Cascader_动态加载_多级请求不同接口(已知第一级调取第二级)

    ELEMENT UI_CASCADER 使用过饿了么级联动态加载的小伙伴应该都知道,lazyLoad本身是一个无差别返回渲染结点的函数. 当我们存在一个需求:已知级联选择器的第一级结点,现在需要通过第 ...

  3. 网络层协议、ARP攻击

    一.IP数据包格式 二.ICMP协议介绍 PING命令 三.ARP协议介绍 四.ARP攻击原理 一.IP数据包格式 网络层的功能 定义了基于IP协议的逻辑地址 连接不同的媒介类型 选择数据通过网络的最 ...

  4. FastAPI 学习之路(一)fastapi--高性能web开发框架

    fastapi是高性能的web框架.他的主要特点是:- 快速编码- 减少人为bug- 直观- 简易- 具有交互式文档 - 高性能 - 基于API的开放标准 支持python 3.6版本. 安装 pip ...

  5. Collections集合工具类和可变参数

    Collections常用的API: public static <T> boolean addAll(Collection<? super T> c, T... elemen ...

  6. scrum项目冲刺_day04总结

    摘要:今日完成任务. 1.图像识别已优化 2.语音识别正在进行 3.搜索功能 正在进行 总任务: 一.appUI页面(已完成) 二.首页功能: 1.图像识别功能(已完成) 2.语音识别功能 3.垃圾搜 ...

  7. Rust之旅 02.通过例子学习自定义类型

    本期文章接上期继续讲述Rust语言中的数据类型,Rust自定义数据类型主要是通过下面这两个关键字来创建: 结构体( struct ): 定义一个结构体(structure) 枚举( enum ): 定 ...

  8. python刷题第二周

    1: 第3章-5 字符转换 (15 分) 本题要求提取一个字符串中的所有数字字符('0'--'9'),将其转换为一个整数输出. 输入格式: 输入在一行中给出一个不超过80个字符且以回车结束的字符串. ...

  9. windows安装python2.7、python3.7和pycharm

    下载安装包 下载可执行文件 安装 安装2.7 安装pycharm

  10. postman 插件安装

    本文只是基于 Chrome 浏览器的扩展插件来进行的安装,并非单独应用程序. 首先,你要台电脑,其次,安装有 Chrome 浏览器,那你接着往下看吧. 1. 官网安装(别看) 打开官网,https:/ ...