【BZOJ3817/UOJ42】Sum(类欧)

题面

BZOJ

UOJ

题解

令\(x=\sqrt r\),那么要求的式子是$$\sum_{d=1}n(-1){[dx]}$$

不难发现,对于每个\(d\)而言的取值只和\([dx]\)的奇偶性相关。

如果\(x\)是个整数,也就是\(r\)是完全平方数的时候,显然是可以直接算答案的。

计算答案的时候显然之和有几个奇数或者几个偶数相关(只要求一个另外一个就是补集)

比如说我们来求有几个是偶数,那么要满足的条件就是\([dx]=2*[\frac{dx}{2}]\)。

先重新写下式子,我们写成这个样子$$\sum_{d=1}^n(1-2*([dx]\ mod\ 2)$$

这个显然成立,当\([dx]\)是偶数的时候贡献是\(1\),奇数的时候贡献是\(0\)。

而\([dx]\ mod\ 2\)可以写成减法的形式。所以原式可以写成

\[\sum_{d=1}^n(1-2*([dx]-2*[\frac{dx}{2}]))
\]

化简之后得到了

\[n+\sum_{d=1}^n (4*[\frac{dx}{2}]-2*[dx])
\]

现在把模型转化一下,变得更加一般一点,那么要求解的东西是$$\sum _{d=1}^n[\frac{ax+b}{c}d]$$

听说这个玩意叫做类欧?类欧几里得算法。

令\(k=\frac{ax+b}{c}\),那么式子可以化简为\(\sum[kd]\)

这里进行分类讨论

1.当\(k>=1\)的时候

\[\begin{aligned}\sum_{d=1}^n[kd]&=[d*(k-[\frac{ax+b}{c}])]+d*[\frac{ax+b}{c}]\end{aligned}
\]

显然后面那一半是可以直接计算的,而前面这一半令\(k'=k-[\frac{ax+b}{c}]\)

我们可以递归处理。

2.\(k<1\)

转化到一个坐标系上面去,我们要求的东西本质上就是有一条直线\(y=kx\),要求解\(x\in[1,n]\)时,与\(x=n\)、\(x\)正半轴围成的三角形内部整点的个数。

我们把这个三角形逆时针旋转\(90\)度,再沿着\(y\)轴翻转过来,让长度为\(n\)的那条边靠着\(y\)轴,这样子翻转过来之后,\(k\)变成了倒数,\(n\)变成了\([nk]\),然后拿矩形减去多出来的部分,不就是矩形减去\(k>=1\)的情况了吗?

再讨论一下取倒数的结果,斜率\(k=\frac{ax+b}{c}\),取倒数之后\(k=\frac{c}{ax+b}\),然后分母有理化一下\(k=\frac{c(ax-b)}{a^2r-b^2}\)。

总的时间复杂度是\(log\)级别的。

#include<iostream>
#include<cstdio>
#include<algorithm>
using namespace std;
#define ll long long
inline int read()
{
int x=0;bool t=false;char ch=getchar();
while((ch<'0'||ch>'9')&&ch!='-')ch=getchar();
if(ch=='-')t=true,ch=getchar();
while(ch<='9'&&ch>='0')x=x*10+ch-48,ch=getchar();
return t?-x:x;
}
double x;ll n,r;
ll Calc(ll a,ll b,ll c,ll n)
{
if(!n)return 0;
ll d=__gcd(a,__gcd(b,c));a/=d;b/=d;c/=d;
ll k=(a*x+b)/c;
if(!k)
{
ll N=(a*x+b)/c*n;
return n*N-Calc(a*c,-b*c,a*a*r-b*b,N);
}
else
return k*n*(n+1)/2+Calc(a,b-c*k,c,n);
}
int main()
{
int T=read();
while(T--)
{
n=read();r=read();x=sqrt(r);
ll k=x;
if(k*k==r)
{
if(k&1)printf("%lld\n",n-2*((n+1)/2));
else printf("%lld\n",n);
}
else printf("%lld\n",n+Calc(1,0,2,n)*4-Calc(1,0,1,n)*2);
}
return 0;
}

【BZOJ3817/UOJ42】Sum(类欧)的更多相关文章

  1. BZOJ3817 清华集训2014 Sum 类欧几里得

    传送门 令\(\sqrt r = x\) 考虑将\(-1^{\lfloor d \sqrt r \rfloor}\)魔改一下 它等于\(1-2 \times (\lfloor dx \rfloor \ ...

  2. UOJ#42. 【清华集训2014】Sum 类欧几里德算法

    原文链接https://www.cnblogs.com/zhouzhendong/p/UOJ42.html 题解 首先我们把式子改写一下: $$(-1)^{\lfloor a\rfloor} \\=1 ...

  3. JZOJ3492数数&&GDOI2018超级异或绵羊——位&&类欧几里得

    JZOJ3492 数数(count) 我们知道,一个等差数列可以用三个数A,B,N表示成如下形式:  B+A,B+2A,B+3A⋯B+NA ztxz16想知道对于一个给定的等差数列,把其中每一项用二进 ...

  4. 2019牛客多校九 I. KM and M (类欧几里得)

    大意: 给定$N,M$, 求$\sum\limits_{K=1}^N \text{(KM)&M}$ 考虑第$i$位的贡献, 显然为$\lfloor\frac{KM}{2^i}\rfloor$为 ...

  5. Kattis - itsamodmodmodmodworld It's a Mod, Mod, Mod, Mod World (类欧几里得)

    题意:计算$\sum\limits_{i=1}^n[(p{\cdot }i)\bmod{q}]$ 类欧模板题,首先作转化$\sum\limits_{i=1}^n[(p{\cdot}i)\bmod{q} ...

  6. [ZZOJ#31]类欧几里得

    [ZZOJ#31]类欧几里得 试题描述 这是一道模板题. 给出 \(a, b, c, n\),请你求出 \(\sum_{x=0}^n{\lfloor \frac{a \cdot x + b}{c} \ ...

  7. 算法马拉松35 E 数论只会Gcd - 类欧几里得 - Stern-Brocot Tree - 莫比乌斯反演

    题目传送门 传送门 这个官方题解除了讲了个结论,感觉啥都没说,不知道是因为我太菜了,还是因为它真的啥都没说. 如果 $x \geqslant y$,显然 gcd(x, y) 只会被调用一次. 否则考虑 ...

  8. bzoj2187 fraction&&hdu3637 Find a Fraction——类欧几里得

    bzoj2187 多组询问,每次给出 $a, b, c, d$,求满足 $\frac{a}{b}  < \frac{p}{q} < \frac{c}{d}$ 的所有二元组 $(p, q)$ ...

  9. CF1182F Maximum Sine【类欧,扩欧】

    题目链接:洛谷 题目描述:求整数$x\in [a,b]$使得$|2px \ mod \ 2q-q|$最小,如果有多个$x$输出最小的. 数据范围:$1\leq a,b,p,q\leq 10^9$ 第一 ...

随机推荐

  1. Angularjs演示Service功能

    在angularjs中,我们可以自定义自己的service.可以说得是自定义的方法,函数. 下面我们一步一步来演示吧:首先为angularjs定义一个app: var demoApp = angula ...

  2. c#通用配置文件读写类与格式转换(xml,ini,json)

    .NET下编写程序的时候经常会使用到配置文件.配置文件格式通常有xml.ini.json等几种,操作不同类型配置文件需要使用不同的方法,操作较为麻烦.特别是针对同时应用不同格式配置文件的时候,很容易引 ...

  3. [开源 .NET 跨平台 Crawler 数据采集 爬虫框架: DotnetSpider] [二] 基本使用

    [DotnetSpider 系列目录] 一.初衷与架构设计 二.基本使用 三.配置式爬虫 四.JSON数据解析与配置系统 五.如何做全站采集 使用环境 Visual Studio 2017 .NET ...

  4. 【nodejs】让nodejs像后端mvc框架(asp.net mvc)一样处理请求--目录(8/8 完结)

    为什么要做这个 在使用nodejs开发过程中,总是发现需要做很多重复性的体力劳动,且因为自身是服务端程序员出身,感觉有一些服务端好的东西其实可以在nodejs上得到应用并能提高一些开发工作效率. 本系 ...

  5. nginx的access.log文件详解

    事实证明,日志文件真的是很重要很重要的.能够帮助我们快速的定位问题,并且知道用户访问的状态,浏览器,Ip,接口地址等,简直可怕.. 一.nginx的access.log(1)对博主而言,日志文件存放在 ...

  6. linux-流程控制语言

    if: for: 增强for循环 while: 统计这个目录下所有文件的大小 编写脚本 执行 help text:

  7. Python_闭包_27

    #闭包:嵌套函数,内部函数 并且必须调用外部函数的变量 def outer(): a = 1 def inner(): print(a) inner() print(inner.__closure__ ...

  8. 牛客OI赛制测试赛-序列-模拟

    哇这道题好坑啊,可能是我太菜了 题意就是叫把一个连续序列分成K组,使得每个组的和都相等 我最开始的想法是由于要分成K组,那我们知道,每组一定有sum(a[i])/k这样我们只需要每次当num==sum ...

  9. 如何在css中设置按钮button中包含图片文字对齐方式

    <el-button class="class-management style="line-heught">班级管理

  10. D. Fun with Integers

    链接 [http://codeforces.com/contest/1062/problem/D] 题意 给你n,让你从2到n这个区间找任意两个数,使得一个数是另一个的因子,绝对值小的可以变为绝对值大 ...