[Contest20180318]求和
题意:求$\sum\limits_{i=1}^n\sum\limits_{j=1}^i\sum\limits_{k=1}^i(i,j,k)$
先令$f(n)=\sum\limits_{i=1}^n\sum\limits_{j=1}^n(n,i,j)$
$\begin{align*}f(n)&=\sum\limits_{i=1}^n\sum\limits_{j=1}^n\sum\limits_{d=1}^n\left[(n,i,j)=d\right]d\\&=\sum\limits_{d|n}\sum\limits_{i=1}^{\frac nd}\sum\limits_{j=1}^{\frac nd}\left[\left(\dfrac nd,i,j\right)=1\right]d\\&=\sum\limits_{d|n}\sum\limits_{i=1}^{\frac nd}\sum\limits_{j=1}^{\frac nd}\sum\limits_{\substack{e|\frac nd\\e|i\\e|j}}d\mu(e)\\&=\sum\limits_{d|n}\sum\limits_{de|n}d\mu(e)\left(\dfrac n{de}\right)^2\end{align*}$
令$T=de$,枚举$T$并将原来的$e$代换
$\begin{align*}f(n)&=\sum\limits_{d|n}\sum\limits_{T|n}d\mu\left(\dfrac Td\right)\left(\dfrac nT\right)^2\\&=\sum\limits_{T|n}\sum\limits_{d|n}d\mu\left(\dfrac Td\right)\left(\dfrac nT\right)^2\end{align*}$
因为式中有$\mu\left(\dfrac Td\right)$所以必须满足$d|T$,也就是改写第二个sigma
$\begin{align*}f(n)&=\sum\limits_{T|n}\sum\limits_{d|T}d\mu\left(\dfrac Td\right)\left(\dfrac nT\right)^2\\&=\sum\limits_{T|n}\varphi(T)\left(\dfrac nT\right)^2\\&=\sum\limits_{T|n}\varphi\left(\dfrac nT\right)T^2\end{align*}$
$\begin{align*}\sum\limits_{i=1}^nf(i)&=\sum\limits_{i=1}^n\sum\limits_{T|i}\varphi\left(\dfrac iT\right)T^2\\&=\sum\limits_{T=1}^nT^2\sum\limits_{j=1}^{\left\lfloor\frac nT\right\rfloor}\varphi(j)\end{align*}$
除法下取整$O\left(\sqrt n\right)$枚举除数,欧拉函数求和直接上杜教筛即可
#include<stdio.h>
#include<map>
using namespace std;
typedef long long ll;
const int T=10000000;
int mod,inv6,inv2;
int mul(int a,int b){return a*(ll)b%mod;}
int ad(int a,int b){return(a+b)%mod;}
int de(int a,int b){return(a-b)%mod;}
int pr[10000010],phi[10000010];
bool np[10000010];
void sieve(){
int i,j,m;
np[1]=1;
phi[1]=1;
m=0;
for(i=2;i<=T;i++){
if(!np[i]){
m++;
pr[m]=i;
phi[i]=i-1;
}
for(j=1;j<=m;j++){
if(pr[j]*(ll)i>T)break;
np[i*pr[j]]=1;
if(i%pr[j]==0){
phi[i*pr[j]]=phi[i]*pr[j];
break;
}
phi[i*pr[j]]=phi[i]*(pr[j]-1);
}
}
for(i=2;i<=T;i++)phi[i]=ad(phi[i],phi[i-1]);
}
int pow(int a,int b){
int s=1;
while(b){
if(b&1)s=mul(s,a);
a=mul(a,a);
b>>=1;
}
return s;
}
int s(int n){return mul(mul(n,n+1),mul(n<<1|1,inv6));}
map<int,int>res;
map<int,int>::iterator it;
int dj(int n){
if(n<=T)return phi[n];
it=res.find(n);
if(it!=res.end())return it->second;
int s,i,nex;
s=mul(mul(n,n+1),inv2);
for(i=2;i<=n;i=nex+1){
nex=n/(n/i);
s=de(s,mul(nex-i+1,dj(n/i)));
}
return res[n]=s;
}
int main(){
int n,i,nex,res;
scanf("%d%d",&n,&mod);
sieve();
inv6=pow(6,mod-2);
inv2=pow(2,mod-2);
res=0;
for(i=1;i<=n;i=nex+1){
nex=n/(n/i);
res=ad(res,mul(s(nex)-s(i-1),dj(n/i)));
}
printf("%d",(res+mod)%mod);
}
[Contest20180318]求和的更多相关文章
- Java程序:从命令行接收多个数字,求和并输出结果
一.设计思想:由于命令行接收的是字符串类型,因此应先将字符串类型转化为整型或其他字符型,然后利用for循环求和并输出结果 二.程序流程图: 三.源程序代码: //王荣荣 2016/9/23 ...
- Java之递归求和的两张方法
方法一: package com.smbea.demo; public class Student { private int sum = 0; /** * 递归求和 * @param num */ ...
- EXCEL中对1个单元格中多个数字求和
如A1=3779.3759.3769.3781.3750,A2对A1中4个数字求和怎么求!请高手赐教! 方法一:在B1中输入公式=SUM(MID(A1,{1,6,11,16,21},4)*1) 方法二 ...
- codevs 1082 线段树区间求和
codevs 1082 线段树练习3 链接:http://codevs.cn/problem/1082/ sumv是维护求和的线段树,addv是标记这歌节点所在区间还需要加上的值. 我的线段树写法在运 ...
- 从sum()求和引发的思考
sum()求和是一个非常简单的函数,以前我的写法是这样,我想大部分和我一样刚开始学习JS的同学写出来的也会是这样. function sum() { var total=null; for(var i ...
- //给定N个整数序列{A1,A2,A3...An},求函数f(i,j)=(k=i~j)Ak的求和
//给定N个整数序列{A1,A2,A3...An},求函数f(i,j)=(k=i~j)Ak的求和 # include<stdio.h> void main() { ,sum1; ]={,- ...
- Ajax中get请求和post请求
我们在使用Ajax向服务器发送数据时,可以采用Get方式请求服务器,也可以使用Post方式请求服务器,那么什么时候该采用Get方式,什么时候该采用Post方式呢? Get请求和Post请求的区别: 1 ...
- POJ 2823 Sliding Window 线段树区间求和问题
题目链接 线段树区间求和问题,维护一个最大值一个最小值即可,线段树要用C++交才能过. 注意这道题不是求三个数的最大值最小值,是求k个的. 本题数据量较大,不能用N建树,用n建树. 还有一种做法是单调 ...
- HDU 1166 敌兵布阵 线段树单点更新求和
题目链接 中文题,线段树入门题,单点更新求和,建一棵树就可以了. #include <iostream> #include <cstdio> #include <cmat ...
随机推荐
- 旋转数组 [ LeetCode ]
原题地址:https://leetcode-cn.com/problems/rotate-array/description/ 给定一个数组,将数组中的元素向右移动 k 个位置,其中 k 是非负数. ...
- jquery教程-Jquery 获取标签个数 size()函数用法
jquery教程-Jquery 获取标签个数 size()函数用法,size() 方法返回被 jQuery 选择器匹配的元素的数量. 语法 $(selector).size() jQuery ...
- HDU1267 下沙的沙子有几粒? 基础DP
题目链接 题意:给定m个H和n个D(1<=n,m<=20),问这些字母构成的序列中,对于任意位置,从左开始数H的累积个数总是不比D的累计数少的排列有多少种. 题解:二维DP,画一个正方形, ...
- bootstrap-table不分页时对数值类型数据的排序
html中的代码 <table id="table"></table> sortData.json的数据如下 [ {"name":&qu ...
- 工作技能===开发不改bug?给你支个招
在测试过程中,不免会遇到开发人员因为一些原因不想修改个别bug的情况.那一般遇到这种问题时,我们该如何去推进开发修改bug呢? 我们先来分析下到底会有哪些原因会导致开发不修改bug 1. 开发与测试对 ...
- 解决spf13-vim编辑php丢失语法颜色问题
$ vim .vim/bundle/PIV/ftplugin/php.vim //注释掉以下: "call s:InitVariable("g:load_doxygen_synta ...
- mysql 使用set names 解决乱码问题
引子: 最近查询公司线上表数据,返现在Xshell控制台打印的数据都是乱码,记得之前瞄过同事都是执行set names UTF8 , 解决的,特记录如下.
- Selenium2+python自动化69-PhantomJS使用【转载】
前言 PhantomJS是一个没有界面的浏览器,本质上是它其实也就是一个浏览器,只是不在界面上展示. PhantomJS非常适合爬虫方面,很多玩爬虫的都喜欢用这个浏览器. 一.PhantomJS环境准 ...
- mysql主从怎么样使主为innodb辅为myisam
MySQL主从复制(linux主+windows从) http://blog.csdn.net/qq_20032995/article/details/54380290 mysql主从怎么样使主为in ...
- 腾讯云 python3+Django
!!!注意:如果已经包含了python3.5,跳过安装3.6版本. !!!本人安装完3.6后,pip3安装的包始终没法安装到3.6目录下,只能安装到3.5目录下 1,安装python3.6(用编译的方 ...