Alternating Sum

题意很简单 就是对一个数列求和。

题解:如果不考虑符号 每一项都是前一项的 (b/a)倍, 然后考虑到符号的话, 符号k次一循环, 那么 下一个同一符号的位置 就是 这一个位置的 (b/a)^k倍了, 然后我们可以发现这个是一个等比数列, 最后我们对等比数列求和就好了。

注意的就是 (b/a)^k % mod == 1的情况,我们可以将前K个数总和在一起, 在一起求等比的和就好了。

我们可以将公式 cir*(1-q^time) / (1 - q) 其中q = (b/a)^k 转化成 cir * (a1^(time*k) - b^(time*k)) / (a1^(time*k) - b^k * a ^((t-1)*k)) 然后因为要进行mod操作 所以 再转换成 cir * (a1^(time*k) - b^(time*k)) *inv( (a1^(time*k) - b^k * a ^((t-1)*k))) 就好了。

代码:

  1. #include<bits/stdc++.h>
  2. using namespace std;
  3. #define LL long long
  4. #define ULL unsigned LL
  5. #define fi first
  6. #define se second
  7. #define lson l,m,rt<<1
  8. #define rson m+1,r,rt<<1|1
  9. #define max3(a,b,c) max(a,max(b,c))
  10. #define min3(a,b,c) min(a,min(b,c))
  11. typedef pair<int,int> pll;
  12. const int INF = 0x3f3f3f3f;
  13. const LL mod = 1e9+;
  14. const int N = 1e5+;
  15. int n, a, b, k;
  16. char str[N];
  17. LL qpow(int a, int b){
  18. LL ret = ;
  19. while(b){
  20. if(b&) ret = (ret*a)%mod;
  21. a = (a%mod*a%mod) % mod;
  22. b >>= ;
  23. }
  24. return ret%mod;
  25. }
  26. int main(){
  27. scanf("%d%d%d%d",&n,&a,&b,&k);
  28. scanf("%s", str);
  29. int len = strlen(str);
  30. LL ans = ;
  31. LL tmp, cir = ;
  32. for(int i = ; i < len; i++){
  33. tmp = qpow(a,n-i) * qpow(b,i) % mod;
  34. if(str[i] == '+') {
  35. cir += tmp;
  36. cir %= mod;
  37. }
  38. else {
  39. cir -= tmp;
  40. if(cir < ) cir += mod;
  41. cir %= mod;
  42. }
  43. }
  44. int time = (n+) / len;
  45. int lf = n+ - len*time;
  46. int be = len*time;
  47. for(int i = ; be <= n; i++, be++){
  48. tmp = qpow(a,n-be) * qpow(b,be) % mod;
  49. if(str[i] == '+') {
  50. ans += tmp;
  51. ans %= mod;
  52. }
  53. else {
  54. ans -= tmp;
  55. if(ans < ) ans += mod;
  56. ans %= mod;
  57. }
  58. }
  59. LL t1 = (qpow(a,len*time) - qpow(b,len*time))%mod;
  60. if(t1 < ) t1 += mod;
  61. LL t2 = (qpow(a,len*time) % mod - qpow(b,len)*qpow(a,(time-)*len)%mod) %mod;
  62. if(t2 < ) t2 += mod;
  63. LL t3 = t1 *(qpow(t2,mod-))% mod;
  64. if(t2!=){
  65. ans = (ans + cir * t3 % mod)%mod;
  66. }
  67. else {
  68. ans = (ans+cir*time%mod)%mod;
  69. }
  70. printf("%I64d", ans);
  71. return ;
  72. }
  73. /*
  74. 8 2 3 2
  75. ++
  76. */

Codeforces 964C Alternating Sum的更多相关文章

  1. codeforces 963A Alternating Sum

    codeforces 963A Alternating Sum 题解 计算前 \(k\) 项的和,每 \(k\) 项的和是一个长度为 \((n+1)/k\) ,公比为 \((a^{-1}b)^k\) ...

  2. Codeforces 963A Alternating Sum(等比数列求和+逆元+快速幂)

    题目链接:http://codeforces.com/problemset/problem/963/A 题目大意:就是给了你n,a,b和一段长度为k的只有'+'和‘-’字符串,保证n+1被k整除,让你 ...

  3. CF 964C Alternating Sum

    给定两正整数 $a, b$ .给定序列 $s_0, s_1, \dots, s_n,s_i$ 等于 $1$ 或 $-1$,并且已知 $s$ 是周期为 $k$ 的序列并且 $k\mid (n+1)$,输 ...

  4. Codeforces 963A Alternating Sum ( 思维 && 数论 )

    题意 : 题目链接 分析 : Tutorial 讲的很清楚 至于为什么这样去考虑 算是一个经验问题吧 如果一个问题要你给出模意义下的答案 就多考虑一下答案是要用逆元构造出来 也就说明有除法的存在 那么 ...

  5. Codeforces 963E Alternating Sum 等比数列+逆元

    题目大意: 看一下样例就明白了 基本思路: 题目中明确提到k为一个周期,稍作思考,把k项看作一项,然后发现这是个等比数列,q=(b/a)^k, 然后重点就是怎样处理等比数列求和表达式中的除法,这个时候 ...

  6. Codeforces 963 A. Alternating Sum(快速幂,逆元)

    Codeforces 963 A. Alternating Sum 题目大意:给出一组长度为n+1且元素为1或者-1的数组S(0~n),数组每k个元素为一周期,保证n+1可以被k整除.给a和b,求对1 ...

  7. Codeforces 396B On Sum of Fractions 数论

    题目链接:Codeforces 396B On Sum of Fractions 题解来自:http://blog.csdn.net/keshuai19940722/article/details/2 ...

  8. CF963A Alternating Sum

    思路:利用周期性转化为等比数列求和. 注意当a != b的时候 bk * inv(ak) % (109 + 9)依然有可能等于1,不知道为什么. 实现: #include <bits/stdc+ ...

  9. codeforces 1217E E. Sum Queries? (线段树

    codeforces 1217E E. Sum Queries? (线段树 传送门:https://codeforces.com/contest/1217/problem/E 题意: n个数,m次询问 ...

随机推荐

  1. 【Java】判断字符串是否含字母

    用正则表达式,示例代码如下: String str = "123abc"; Pattern.compile("(?i)[a-z]]").matcher(str) ...

  2. 【Algorithm】选择排序法

    简单的选择排序法思想: * 首先找到数组中最小的元素,将它和数组第一个元素互换位置(如果第一个元素就是最小那么它就和自己交换). * 其次,在剩下的元素中找到最小的元素,将它与数组的第二个元素互换位置 ...

  3. hdoj 4706 Children's Day

    题目意思就是用a-z组成一个N,然后到z后又跳回a,输出宽从3到10的N. #include <stdio.h> #include <string.h> char s[14][ ...

  4. Danjgo学习笔记(一)

    ## 创建项目: 1. 通过命令行的方式:首先要进入到安装了django的虚拟环境中.然后执行命令: ``` django-admin startproject [项目的名称] ``` 这样就可以在当 ...

  5. SpringBoot:如何优雅地处理全局异常?

    之前用springboot的时候,只知道捕获异常使用try{}catch,一个接口一个try{}catch,这也是大多数开发人员异常处理的常用方式,虽然屡试不爽,但会造成一个问题,就是一个Contro ...

  6. 【POJ - 3280】Cheapest Palindrome(区间dp)

    Cheapest Palindrome 直接翻译了 Descriptions 给定一个字符串S,字符串S的长度为M(M≤2000),字符串S所含有的字符的种类的数量为N(N≤26),然后给定这N种字符 ...

  7. echarts legend 限制规定显示个数,显示省略号,修改默认样式

    类似百度统计,有的时候legend的个数比较多,但是前端需要控制初始化显示的个数,以及最多显示的条数,先看效果图: 先给代码: <!DOCTYPE html> <html lang= ...

  8. 洛谷 P2024 [NOI2001]食物链

    题意简述 有人用两种说法对这 N 个动物所构成的食物链关系进行描述: 1."1 X Y",表示 X 和 Y 是同类. 2."2 X Y",表示 X 吃 Y . ...

  9. 欢迎加入我的知识星球:C语言解惑课堂

    我在知识星球上开通了一个有关C语言基础答疑解惑的星球,它叫做:“C语言解惑课堂”.看这名字你就知道虽然有点俗,俗才贴近你的真正需求嘛!这是一个专门帮助C语言初学者答疑解惑的课堂.嗯~~~,关于这个星球 ...

  10. Jvm内存泄漏

    内存泄漏和内存溢出的关系 内存泄露:指程序中动态分配内存给一些临时对象,但是对象不会被GC所回收,它始终占用内存.即被分配的对象可达但已无用. 内存溢出:指程序运行过程中无法申请到足够的内存而导致的一 ...