uva 10518 - How Many Calls?(矩阵快速幂)

╰半夏微凉° 2022-05-12 23:16 235阅读 0赞

题目链接:uva 10518 - How Many Calls?

公式f(n) = 2 * F(n) - 1, F(n)用矩阵快速幂求。

  1. #include <stdio.h>
  2. #include <string.h>
  3. long long n;
  4. int b;
  5. struct state {
  6. int s[2][2];
  7. state(int a = 0, int b = 0, int c = 0, int d = 0) {
  8. s[0][0] = a, s[0][1] = b, s[1][0] = c, s[1][1] = d;
  9. }
  10. }tmp(1, 0, 0, 1), c(1, 1, 1, 0);
  11. state count(const state& p, const state& q) {
  12. state f;
  13. for (int i = 0; i < 2; i++)
  14. for (int j = 0; j < 2; j++)
  15. f.s[i][j] = (p.s[i][0] * q.s[0][j] + p.s[i][1] * q.s[1][j]) % b;
  16. return f;
  17. }
  18. state solve(long long k) {
  19. if (k == 0) return tmp;
  20. else if (k == 1) return c;
  21. state a = solve(k / 2);
  22. a = count(a, a);
  23. if (k % 2) a = count(a, c);
  24. return a;
  25. }
  26. int main () {
  27. int cas = 1;
  28. while (scanf("%lld%d", &n, &b), n || b) {
  29. state ans = solve(n);
  30. printf("Case %d: %lld %d %d\n", cas++, n, b,(2 * ans.s[0][0] - 1 + b) % b);
  31. }
  32. return 0;
  33. }

发表评论

表情:
评论列表 (有 0 条评论,235人围观)

还没有评论,来说两句吧...

相关阅读

    相关 UVA 11551(矩阵快速)

    题目来源:[点击打开链接][Link 1] 题目题意:题目给我们n个数和r次操作。接在输入n行,表示每次将第i个数变成它后面几个位置的和。重复r次。 题目分析:我们按照题目