• HDU5970 最大公约数


    HDU5970 最大公约数

    Describe

    有这样一个有关最大公约数的函数:
    函数 f(x, y):

    {
         c=0
         当 y>0:
         {
              c +=1
              t = x % y
              x = y
              y = t
          }
          返回 c * x * x
    }
    

    给出三个正整数n,m,p,你需要计算: (sum_{i=1}^{n}sum_{j=1}^{m} lfloor frac{i*j}{f(i,j)} floor) 对p取模的结果。

    Input

    包含多组测试数据。
    第一行有一个正整数,表示数据的组数。
    接下来每行表示一组数据,这一行有三个空格隔开的正整数n,m,p。
    保证 n <= 666,666,666, m <= 666, p <= 666,666,666。
    最终的测试数据中共有66组数据,并且每一个n,m,p都是在上述范围内均匀随机生成的。

    Output

    对于每个输入数据输出一行,这一行只包含一个整数即答案。

    Sample Input

    3
    10 5 23333
    100 10 23333
    1000 20 23333
    

    Sample Output

    271
    22359
    10998
    

    Solution

    ​ f(x,y)可以分析出是(gcd(x,y)^2)*c,c是x,y辗转相除的次数。

    ​ 所以我们可以知道,f(x,y)中的x和y顺序可换结果一样,还知道只要如果gcd()相等且第一次运算x%y相等(辗转相除的次数相等),f()就相等。

    即:f ( i , j ) = f ( j , i );

    ​ f ( i , j ) = f(i + j * k, j );

    ​ 所以有一个推导过程 (sum_{i=1}^{n}sum_{j=1}^{m} lfloor frac{i*j}{f(i,j)} floor) =img

  • 相关阅读:
    课程总结
    每日总结66
    每日总结65
    每日总结64
    每日总结63
    每日总结62
    每日总结61
    每日总结60
    偶滴点NET复习
    内部异常SocketException由于目标计算机积极拒绝
  • 原文地址:https://www.cnblogs.com/Lour688/p/12994190.html
Copyright © 2020-2023  润新知