上模板题例题:

[CQOI2007]余数求和

洛谷

BZOJ

题目大意:求 $\sum^n_{i=1}k\ mod\ i$ 的值。

等等……这题就学了三天C++的都会吧?

$1\leq n,k\leq 10^9$。(一口老血喷到屏幕上)

$O(n)$ 行不通了,考虑别的做法。


我们来看一下 $\lfloor\frac{x}{i}\rfloor$ 的值。

$x=9$:(不包括0,只有4种取值?)

i

1 2 3 4 5 6 7 8 9 10
x/i 9 4 3 2 1 1 1 1 1

0

$x=12$:(不包括0,只有6种取值?)

i 1 2 3 4 5 6 7 8 9 10 11 12
x/i 12 6 4 3 2 2 1 1 1 1 1

1

貌似 $\lfloor\frac{x}{i}\rfloor$ 取值数不是很多?

我们来估算一下 $\lfloor\frac{x}{i}\rfloor$ 的不同取值个数:

当 $1\leq i\leq \lfloor\sqrt{x}\rfloor$ 时,$i$ 都只有 $\lfloor\sqrt{x}\rfloor$ 个,不同的取值数肯定不会更多。

当 $\lfloor\sqrt{x}\rfloor\leq i\leq x$ 时,$1\leq\lfloor\frac{x}{i}\rfloor\leq\lfloor\sqrt{x}\rfloor$,不同的取值数肯定 $\leq\lfloor\sqrt{x}\rfloor$ 个。

综上,不同取值数是 $\sqrt{x}$ 级别的。

然后我们可以发现相同的数是连续的一段。那么我们可以通过这个特点把 $\lfloor\frac{x}{i}\rfloor$ 分成几段,每一段的数相等,那么这一段的和就是长度 $\times$ 这个相同的数。

因为不同取值只有 $\sqrt{x}$ 个,所以这样加速后的时间复杂度是 $O(\sqrt{x})$,比 $O(x)$ 快了不少。这就是整除分块。


回到原题。

求 $\sum^n_{i=1}k\ mod\ i$ 的值。

这个……看着和整除分块没什么大关系的样子?

我们看这个 $mod$ 真碍眼,把它拆开。

$k\ mod\ i=k-i\times\lfloor\frac{k}{i}\rfloor$

那么就有:

$\ \sum^n_{i=1}k\ mod\ i$

$=\sum^n_{i=1}k-i\times\lfloor\frac{k}{i}\rfloor$

$=nk-\sum^n_{i=1}i\times\lfloor\frac{k}{i}\rfloor$

后面这个式子貌似可以整除分块了……怎么算呢?

我们考虑 $[l,r]$ 这段区间的求和,其中 $\lfloor\frac{k}{i}\rfloor=x:i\in [l,r]$。

$\ \sum^r_{i=l}i\times\lfloor\frac{k}{i}\rfloor$

$=\sum^r_{i=l}i\times x$

$=x\sum^r_{i=l}i$

$=\frac{x(l+r)(r-l+1)}{2}$

这样就不是很难了。


话说讲了这么久也没讲怎么枚举一段相同区间的左端点和右端点。

我们这样扫描:

一开始 $l=1$ 显而易见。

求出对应的 $r$。

这个区间求完了,下一个 $l$ 应该是下一个还没扫过的位置,即 $l=r+1$。

一直重复直到 $l$ 到了上界,也就是扫完了。

怎么求对应的 $r$ 呢?

既然 $\lfloor\frac{k}{l}\rfloor=\lfloor\frac{k}{r}\rfloor$,且 $r$ 是右端点(最大)

那么 $r=\frac{k}{\frac{k}{l}}$。(当然可能要跟枚举上界取一个min,视情况而定)

整除分块模板大概如下:

 for(int l=,r;l<=n;l=r+){
r=n/(n/l);
//do something...
}

那么这题代码实现就不难了。需要注意本题有不少坑点,详见代码。(没错,代码并没有你想象的那么长!)

时间复杂度貌似是 $O(\sqrt{min(k,n)})$,空间复杂度 $O(1)$

#include<iostream>
#include<cmath>
using namespace std;
typedef long long ll; //long long是需要的
ll n,k,ans;
int main(){
cin>>n>>k;
ans=n*k;
for(ll l=,r;l<=min(n,k);l=r+){ //与上界取min!
r=min(k/(k/l),n); //与上界取min!
ans-=(k/l)*(l+r)*(r-l+)/;
}
cout<<ans<<endl;
}

整除分块的超简短代码

另外再推荐几题。抱歉只找到一题,虽说也不错

洛谷P3935 Calculating 题解戳我

整除分块学习笔记+[CQOI2007]余数求和(洛谷P2261,BZOJ1257)的更多相关文章

  1. 莫比乌斯反演&整除分块学习笔记

    整除分块 用于计算$\sum_{i=1}^n f(\lfloor{n/i} \rfloor)*i$之类的函数 整除的话其实很多函数值是一样的,对于每一块一样的商集中处理即可 若一个商的左边界为l,则右 ...

  2. 莫比乌斯反演学习笔记+[POI2007]Zap(洛谷P3455,BZOJ1101)

    先看一道例题:[POI2007]Zap BZOJ 洛谷 题目大意:$T$ 组数据,求 $\sum^n_{i=1}\sum^m_{j=1}[gcd(i,j)=k]$ $1\leq T\leq 50000 ...

  3. P2261 [CQOI2007]余数求和 【整除分块】

    一.题面 P2261 [CQOI2007]余数求和 二.分析 参考文章:click here 对于整除分块,最重要的是弄清楚怎样求的分得的每个块的范围. 假设$ n = 10 ,k = 5 $ $$  ...

  4. [洛谷P2261] [CQOI2007]余数求和

    洛谷题目链接:[CQOI2007]余数求和 题目背景 数学题,无背景 题目描述 给出正整数n和k,计算G(n, k)=k mod 1 + k mod 2 + k mod 3 + - + k mod n ...

  5. 洛谷 P2261 [CQOI2007]余数求和 解题报告

    P2261 [CQOI2007]余数求和 题意: 求\(G(n,k)=\sum_{i=1}^n k \ mod \ i\) 数据范围: \(1 \le n,k \le 10^9\) \(G(n,k)\ ...

  6. 洛谷——P2261 [CQOI2007]余数求和

    P2261 [CQOI2007]余数求和 关键在于化简公式,题目所求$\sum_{i=1}^{n}k\mod i$ 简化式子,也就是$\sum_{i=1}^{n}(k-\frac{k}{i}\time ...

  7. [Luogu 2261] CQOI2007 余数求和

    [Luogu 2261] CQOI2007 余数求和 这一定是我迄今为止见过最短小精悍的省选题了,核心代码 \(4\) 行,总代码 \(12\) 行,堪比小凯的疑惑啊. 这题一看暴力很好打,然而 \( ...

  8. 题解 P2261【[CQOI2007]余数求和】

    P2261[[CQOI2007]余数求和] 蒟蒻终于不看题解写出了一个很水的蓝题,然而题解不能交了 虽然还看了一下自己之前的博客 题目要求: \[\sum_{i=1}^{n}{k \bmod i} \ ...

  9. [Luogu P2261] [CQOI2007]余数求和 (取模计算)

    题面 传送门:https://www.luogu.org/problemnew/show/P2261 Solution 这题显然有一个O(n)的直接计算法,60分到手. 接下来我们就可以拿出草稿纸推一 ...

随机推荐

  1. Flutter - JSON to Dart,一个json转dart实体的网站

    如你所见,一个json转dart实体的网站,https://javiercbk.github.io/json_to_dart/

  2. Luogu P4322 [JSOI2016]最佳团体

    JZdalao昨天上课讲的题目,话说JSOI的题目是真的不难,ZJOI的题目真的是虐啊! 题意很简单,抽象一下就是:有一棵树,一次只能选从根到某个节点上的链上的所有点,问从中取出k个节点所得到的总价值 ...

  3. 欧几里得算法(及扩展)&&快速幂(二分+位运算)

    最近在二中苦逼地上课,天天听数论(当然听不懂) 但是,简单的还是懂一点的 1.欧几里得算法 说得这么高级干什么,gcd入门一个月的人都会吧,还需要BB? 证明可参照其他博客(不会),主要就是gcd(a ...

  4. CCNode详解

    cocos2d的所有类都以CC开头,那么实际上这个类的名字就是Node,类如其名,这个类的实例就是一个节点.Cocos2d的类是树状继承的,而在内存中,各个实例之间也是以“树”这种数据结构相关联的., ...

  5. H5——video百花齐放(浏览器自带的播放器)

    前言 手机自带浏览器的H5播放器 真是百花齐放啊(各个手机厂家有各个厂家的控件UI) 需求 手机浏览器木有控件条 自动播放 全屏处理 监控进度条 快进后退 自动播放 自动播放就给跪了 ios 安卓 为 ...

  6. 蓝牙学习笔记二(Android连接问题)

    可以通过以下两点加速蓝牙连接: 1.更新连接参数 interval:连接间隔(connection intervals ),范围在 7.5 毫秒 到 4 秒. latency:连接延迟 ... 还有一 ...

  7. CSS 天坑 I - 字体单位

    首先,本文所讨论的“坑”是在做回应式网页设计( Responsive Web Design 以下简称 RWD)时显现的,如果你还只是在做传统的Web设计这算不上是一个坑,因为传统的Web页面是死的,不 ...

  8. 对NP问题的一点感想

    一.概述 回忆欧拉回路问题,要求找出一条经过图的每条边恰好一次的路径,这个问题是线性可解的.哈密尔顿圈问题是找一个简单圈,该圈包括图的每一个顶点.对于这个问题,现在还没有发现线性算法. 对于有向图的单 ...

  9. .Net Core 分布式微服务框架 - Jimu 添加 Swagger 支持

    系列文章 .Net Core 分布式微服务框架介绍 - Jimu .Net Core 分布式微服务框架 - Jimu 添加 Swagger 支持 一.前言 最近有空就优化 Jimu (一个基于.Net ...

  10. git笔记:通过给grunt-inline打tag看tag操作

    晚上review了下grunt-inline的issues,看到有个兄弟pull request,修正了0.3.0版本的一个bug.于是就merge了下,然后发布了0.3.1版本(这里). npm p ...