/*
HDU 6051 - If the starlight never fade [ 原根,欧拉函数 ] | 2017 Multi-University Training Contest 2
题意:
给定 m,p, p 是素数
设 f(i) 是 满足 (x+y)^i ≡ x^i mod p 的 (x,y) 对数 且 1 ≤ x ≤ p-1 , 1 ≤ y ≤ m
求 ∑[1≤i≤p-1] i*f(i)
限制: m ≤ p-1, 2 ≤ p ≤ 1e9
分析:
设 g 为 p 的原根,则x,y可表示为 x = g^a, y = g^b
(x+y)^i ≡ x^i (mod p)
(g^a + g^b)^i ≡ g^ai (mod p)
(1 + g^(b-a))^i ≡ 1 (mod p)
设 g^k = 1 + g^(b-a),则 g^ki ≡ 1 (mod p)
则 k 满足 ki % (p-1) == 0 ,即 k 是 (p-1)/gcd(i, p-1) 的倍数
由于 0 < k < p-1 , 则k的取值有 (p-1) / ((p-1)/gcd(i, p-1)) - 1 = gcd(i, p-1)-1 个
回带 1 + y/x = g^k
x = y * (g^k-1)^(-1)
x = y * (g^k-1)^(φ(p)-1)
则 当y固定时, x, k 一一对应,x的取值也有 gcd(i, p-1)-1 个 ans = ∑[1≤i≤p-1] i*f(i)
= ∑[1≤i≤p-1] i * m * (gcd(i, p-1)-1)
= m * ( ∑[1≤i≤p-1] i * gcd(i, p-1) - p*(p-1)/2) 求解 ∑[1≤i≤n] i * gcd(i, n)
= ∑[1≤i≤n] i ∑[k|n] k * [gcd(i, n) == k]
= ∑[k|n] ∑[1≤i≤n] i * k * [gcd(i, n) == k]
= ∑[k|n] k^2 ∑[1≤i≤n/k] i * [gcd(i, n/k) == 1] 求解 ∑[1≤i≤n] i * [gcd(i, n) == 1]
= (∑[1≤i≤n] i * [gcd(i, n) == 1] + ∑[1≤i≤n] (n-i) * [gcd(i, n-i) == 1]) / 2
= ∑[1≤i≤n] (i+n-i)/2 * [gcd(i, n) == 1]
= (n * φ(n) + [n==1]) / 2
*/
#include <bits/stdc++.h>
using namespace std;
#define LL long long
const LL MOD = 1e9+7;
LL phi(LL n) {
LL ans = n;
for (LL i = 2; i * i <= n; i++) {
if (n % i == 0) {
ans -= ans / i;
while (n % i == 0) n /= i;
}
}
if (n > 1) ans -= ans/n;
return ans;
}
LL Cal(LL x, LL n)
{
LL res = 1;
res *= ( (n/x)*phi(n/x) + bool(n/x == 1) ) / 2;
res %= MOD;
res *= x*x % MOD;
res %= MOD;
return res;
}
LL p, m;
int main()
{
int t; scanf("%d", &t);
for (int tt = 1; tt <= t; tt++)
{
scanf("%lld%lld", &m, &p);
LL ans = 0;
for (LL i = 1; i*i <= p-1; i++)
{
if (i*i == p-1)
{
ans += Cal(i, p-1);
ans %= MOD;
}
else if ((p-1)%i == 0)
{
ans += Cal(i, p-1) + Cal((p-1)/i, p-1);
ans %= MOD;
}
}
ans += MOD - p*(p-1)/2 % MOD;
ans = ans % MOD * m % MOD;
printf("Case #%d: %lld\n", tt, ans);
}
}

  

HDU 6051 - If the starlight never fade | 2017 Multi-University Training Contest 2的更多相关文章

  1. HDU 6051 If the starlight never fade(原根+推式子)

    题目大意: 设\(f(i)\)为使\((x+y)^i \equiv x^i (mod\ p)\)成立的(x,y)的对数.其中\(1 \leq x \leq p-1 , 1\leq y\leq m\), ...

  2. HDU 6343.Problem L. Graph Theory Homework-数学 (2018 Multi-University Training Contest 4 1012)

    6343.Problem L. Graph Theory Homework 官方题解: 一篇写的很好的博客: HDU 6343 - Problem L. Graph Theory Homework - ...

  3. hdu 5335 Walk Out(bfs+斜行递推) 2015 Multi-University Training Contest 4

    题意—— 一个n*m的地图,从左上角走到右下角. 这个地图是一个01串,要求我们行走的路径形成的01串最小. 注意,串中最左端的0全部可以忽略,除非是一个0串,此时输出0. 例: 3 3 001 11 ...

  4. 2017 Wuhan University Programming Contest (Online Round) Lost in WHU 矩阵快速幂 一个无向图,求从1出发到达n最多经过T条边的方法数,边可以重复经过,到达n之后不可以再离开。

    /** 题目:Lost in WHU 链接:https://oj.ejq.me/problem/26 题意:一个无向图,求从1出发到达n最多经过T条边的方法数,边可以重复经过,到达n之后不可以再离开. ...

  5. 2017 Wuhan University Programming Contest (Online Round) C. Divide by Six 分析+模拟

    /** 题目:C. Divide by Six 链接:https://oj.ejq.me/problem/24 题意:给定一个数,这个数位数达到1e5,可能存在前导0.问为了使这个数是6的倍数,且没有 ...

  6. 2017 Wuhan University Programming Contest (Online Round) B Color 树形dp求染色方法数

    /** 题目:Color 链接:https://oj.ejq.me/problem/23 题意:给定一颗树,将树上的点最多染成m种颜色,有些节点不可以染成某些颜色.相邻节点颜色不同.求染色方法数. 思 ...

  7. HDU 6300.Triangle Partition-三角形-水题 (2018 Multi-University Training Contest 1 1003)

    6300.Triangle Partition 这个题就是输出组成三角形的点的下标. 因为任意三点不共线,所以任意三点就可以组成三角形,直接排个序然后输出就可以了. 讲道理,没看懂官方题解说的啥... ...

  8. 2017 Wuhan University Programming Contest (Online Round) D. Events,线段树区间更新+最值查询!

    D. Events 线段树区间更新查询区间历史最小值,看似很简单的题意写了两天才写出来. 题意:n个数,Q次操作,每次操作对一个区间[l,r]的数同时加上C,然后输出这段区间的历史最小值. 思路:在线 ...

  9. 2015多校联合训练赛 hdu 5308 I Wanna Become A 24-Point Master 2015 Multi-University Training Contest 2 构造题

    I Wanna Become A 24-Point Master Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 ...

随机推荐

  1. 使用kubeadm进行单master(single master)和高可用(HA)kubernetes集群部署

    kubeadm部署k8s 使用kubeadm进行k8s的部署主要分为以下几个步骤: 环境预装: 主要安装docker.kubeadm等相关工具. 集群部署: 集群部署分为single master(单 ...

  2. JSP和Servlet异常处理转发

    <error-page> <!-- 指明异常类型. --> <exception-type>java.lang.ArrayIndexOutOfBoundsExcep ...

  3. springboot+mybatis 用redis作二级缓存

    1.加入相关依赖包: <?xml version="1.0" encoding="UTF-8"?> <project xmlns=" ...

  4. (五)Spring 中的 aop

    目录 文章目录 AOP概念 AOP原理 AOP术语 **`Spring`** 中的 **`aop`** 的操作 使用 `AspectJ` 实现 `aop` 的两种方式 AOP概念 浅理解 aop :面 ...

  5. # 双值Hash

    双值Hash 简单介绍 Hash的应用:Hash其实就像一个加密过程,很多加密算法都会用到Hash,像GitHub中生成的token值也是Hash的结果. Hash冲突:简单来说就是不同的数映射到了同 ...

  6. 16.screen相关

    screen -S yourname -> 新建一个叫yourname的sessionscreen -ls -> 列出当前所有的sessionscreen -r yourname -> ...

  7. MACD中短线交易系统

    1.MA5.MA10金叉,且股价收盘站稳5日均线 2.MACD金叉 3.MACD红绿柱 a.MACD红柱发散,表示多头力量增强,此时买入或加仓 b.MACD红柱收缩,表示多头力量减弱,此时卖出或减仓 ...

  8. 正则表达式 第五篇:C# 正则表达式

    原文:正则表达式 第五篇:C# 正则表达式 本文整理C#正则表达式的元字符,正则表达式是由字符构成的表达式,每个字符代表一个规则,表达式中的字符分为两种类型:普通字符和元字符.普通字符是指字面含义不变 ...

  9. Attribute自定义特性+Asp.net MVC中的filter详解

    转载自:http://blog.csdn.net/wangyy130/article/details/44241957 一.filter简介 在了解自定义特性前,先引入一个概念filter,它是MVC ...

  10. springboot+mybatis调用oracle存储过程

    1 存储过程参数为VARCHAR 代码逻辑:controller层定义实体类对象entity,并entity.set给存储过程的输入参数赋值,把赋值后的实体类通过service层传到dao层,然后通过 ...