luoguP3768 简单的数学题
题目链接
题解
上面那个式子的最后一步,需要定理
用数学归纳法证明
\(S1=1^3=1^2\)
\(S2=1^3+2^3=9=3^2=(1+2)^2\)
\(S3=1^3+2^3+3^3=36=6^2=(1+2+3)^2\)
\(S4=1^3+2^3+3^3+4^3=100=10^2=(1+2+3+4)^2\)
\(S5=1^3+2^3+3^3+4^3+5^3=15^2=(1+2+3+4+5)^2\)
假设当\(n=k\)时,有\(Sk=1^3+2^3+...+k^3=(1+2+...+k)^2\)
则当\(n=(k+1)\)时,
\(S(k+1)=Sk+ak=(1+2+...+k)^2+(k+1)^3\)
\(=[k(k+1)/2]^2+(k+1)^3\)
\(=(k+1)^2[k^2/4+k+1]\)
\(=(k+1)^2[(k^2+4k+4)/4]\)
\(=(k+1)^2(k+2)^2/4\)
\(=[(k+1)(k+2)/2]^2\)
\(=(1+2+...+k+1)^2\)
对于前面那个杜教筛
代码
#include<map>
#include<cstdio>
#include<algorithm>
inline int read() {
int x = 0,f = 1;
char c = getchar();
while(c < '0' || c > '9') { if(c == '-')f = -1; c = getchar(); }
while(c <= '9' && c >= '0') x = x * 10 + c - '0',c = getchar();
return x * f;
}
#define LL long long
const int maxn = 10000000;
LL Max = maxn;
std:: map<LL,LL>M;
LL Inv6,Inv2,Phi[maxn + 7], phi[maxn + 7],mod;
bool isprime[maxn + 7];
int prime[maxn],cnt = 0;
LL fstpow(LL a,LL b) {
LL ret = 1;
for(;b;b >>= 1,a = a * a % mod)
if(b & 1) ret = ret * a % mod;
return ret;
}
void getphi() {
phi[1] = 1;
for(int i = 2;i <= Max;++ i) {
if(!isprime[i]) prime[++ cnt] = i,phi[i] = (i - 1) % mod;
for(int j = 1;j <= cnt && i * prime[j] <= Max;++ j) {
isprime[i * prime[j]] = 1;
if(i % prime[j]) phi[i * prime[j]] = 1ll * phi[i] * phi[prime[j]] % mod;
else {
phi[i * prime[j]] = 1ll * phi[i] * prime[j] % mod;
break;
}
}
}
for(int i = 1;i <= Max;++ i) Phi[i] = 1ll * phi[i] * i % mod * i % mod;
for(int i = 1;i <= Max;++ i) Phi[i] += Phi[i - 1] , Phi[i] %= mod;
}
//---------------------------------------------
LL S1(LL r) { r %= mod;return r * (r + 1) % mod * (r + r + 1) % mod * Inv6 % mod; }
LL S2(LL r) { r %= mod;return r * (r + 1) % mod * Inv2 % mod; }
LL S(LL n) {
if(n <= maxn) return Phi[n];
if(M[n]) return M[n];
LL he = S2(n) * S2(n) % mod , t;
for(LL i = 2,l;i <= n;i = l + 1) {
l = n / (n / i);
t = ((S1(l) - S1(i - 1)) % mod + mod) % mod;
he -= t * S(n / i) % mod,he %= mod;
}
return M[n] = (he + mod) % mod;
}
LL solve(LL n) {
LL res = 0;
for(LL i = 1,l,t ;i <= n;i = l + 1) {
l = n / (n / i),t = S2(n/i);
res += ((S(l) - S(i - 1) + mod) % mod * (t * t % mod)) % mod;
res %= mod;
}
return (res + mod) % mod;
}
int main() {
LL n;
scanf("%lld%lld",&mod,&n);
Max = std::min(Max,n);
Inv2 = fstpow(2,mod - 2),Inv6 = fstpow(6,mod-2);
getphi();
printf("%lld\n",solve(n));
return 0;
}
luoguP3768 简单的数学题的更多相关文章
- luoguP3768简单的数学题
大佬们绕道吧(或跳到错误&启发后下一根横线后) 这道题吧正解是莫比乌斯反演吧,但本人有一种独创玄妙的想法去偏分 这道题是让我们求这个对吧 \((\sum_{i=1}^n\sum_{j=1}^n ...
- [题解] LuoguP3768 简单的数学题
Description 传送门 给一个整数\(n\),让你求 \[ \sum\limits_{i=1}^n \sum\limits_{j=1}^n ij\gcd(i,j) \] 对一个大质数\(p\) ...
- 【数学】HPU--1037 一个简单的数学题
1037: 一个简单的数学题 [数学] 时间限制: 1 Sec 内存限制: 128 MB提交: 259 解决: 41 统计 题目描述 小明想要知道$a^b$的值,但是这个值会非常的大. 所以退而求其次 ...
- 【Luogu3768】简单的数学题(莫比乌斯反演,杜教筛)
[Luogu3768]简单的数学题(莫比乌斯反演,杜教筛) 题面 洛谷 \[求\sum_{i=1}^n\sum_{j=1}^nijgcd(i,j)\] $ n<=10^9$ 题解 很明显的把\( ...
- 【LG3768】简单的数学题
[LG3768]简单的数学题 题面 求 \[ (\sum_{i=1}^n\sum_{j=1}^nij\text{gcd}(i,j))\text{mod}p \] 其中\(n\leq 10^{10},5 ...
- 洛谷 P3768 简单的数学题 解题报告
P3768 简单的数学题 题目描述 由于出题人懒得写背景了,题目还是简单一点好. 输入一个整数\(n\)和一个整数\(p,\)你需要求出\((\sum_{i=1}^n\sum_{j=1}^n ijgc ...
- loj#6229 这是一道简单的数学题
\(\color{#0066ff}{ 题目描述 }\) 这是一道非常简单的数学题. 最近 LzyRapxLzyRapx 正在看 mathematics for computer science 这本书 ...
- 「洛谷P3768」简单的数学题 莫比乌斯反演+杜教筛
题目链接 简单的数学题 题目描述 输入一个整数n和一个整数p,你需要求出 \[\sum_{i=1}^n\sum_{j=1}^n (i\cdot j\cdot gcd(i,j))\ mod\ p\] ...
- P3768 【简单的数学题】
P3768 [简单的数学题] \(Ans=\sum ^{n}_{i=1}\sum ^{n}_{j=1}ijgcd(i,j)\) \(=\sum ^{n}_{i=1}\sum ^{n}_{j=1}ij\ ...
随机推荐
- 数据结构(三)串---KMP模式匹配算法
(一)定义 由于BF模式匹配算法的低效(有太多不必要的回溯和匹配),于是某三个前辈发表了一个模式匹配算法,可以大大避免重复遍历的情况,称之为克努特-莫里斯-普拉特算法,简称KMP算法 (二)KMP算法 ...
- BFS简单题套路_Codevs 1215 迷宫
BFS 简单题套路 1. 遇到迷宫之类的简单题,有什么行走方向的,先写下面的 声明 ; struct Status { int r, c; Status(, ) : r(r), c(c) {} // ...
- ASP.NET MVC学习笔记-----ControllerFactory
上面这张图是asp.net mvc的工作流程图,我们可以看到当一个http请求来临时,首先需要经过路由系统,路由系统从中获取一些路由信息,然后ControllerFactory根据所得到的路由信息生成 ...
- 蓝桥杯 问题 1110: 2^k进制数 (排列组合+高精度巧妙处理)
题目链接 题目描述 设r是个2^k 进制数,并满足以下条件: (1)r至少是个2位的2^k 进制数. (2)作为2^k 进制数,除最后一位外,r的每一位严格小于它右边相邻的那一位. (3)将r转换为2 ...
- linux中serial driver理解【转】
转自:http://blog.csdn.net/laoliu_lcl/article/details/39967225 英文文档地址:myandroid/kernel_imx/Documentatio ...
- 协议中UART的两种模式 【转】
转自:http://wjf88223.blog.163.com/blog/static/3516800120104179327286/ ^^…… 协议栈中UART有两种模式:1.中断2.DMA 对于这 ...
- 一个完整的Installshield安装程序实例-转
一个完整的Installshield安装程序实例—艾泽拉斯之海洋女神出品(一)---基本设置一 前言 Installshield可以说是最好的做安装程序的商业软件之一,不过因为功能的太过于强大,以至于 ...
- MVC Autofac依赖注入
通过Dll实现全部类的属性注入,该演示实例主要通过多层架构中单一的对象方式来演示,没有采取接口的方式, 新建AutoFacHelper类,如下代码: public class AutoFacHelpe ...
- 纯js遍历json获取值动态为select添加option
遍历json数组 并动态为select添加option 直接上代码,重要部分有注解 <!DOCTYPE html> <html lang="en"> < ...
- JAVA 基础基本语法---常量与变量
JAVA 基础基本语法---常量与变量 语法:计算机能够识别的语言的规则: 0. 基本语法 编写Java程序时,应注意以下几点: 大小写敏感:Java是大小写敏感的,这就意味着标识符Hello与hel ...