【LG5171】Earthquake
【LG5171Earthquake】
题面
题解
本题需要用到类欧几里得算法。
前置知识:类欧几里得
就是求函数$$\varphi (a,b,c,n)=\sum_{i=0}^n \left\lfloor\frac {ai+b}c\right\rfloor$$
的值(其实还有两种形式,但是我还不会这里不做介绍)。
它的几何意义是直线\(y=\frac {ax+b}c\)在\([0,n]\)下方或过直线的第一象限内的整点数
令\(\xi(i)=\lfloor\frac {ai+b}c\rfloor\),
由结论\(\lfloor\frac{Ax}y\rfloor = \lfloor\frac{A(x\;\bmod\;y)}y\rfloor + A\lfloor\frac xy\rfloor\),
可以得到
\xi(i)&=\left\lfloor\frac{ai}c+\frac bc\right\rfloor
\\&=\left\lfloor\frac{(a\bmod c)i+(b\bmod c)} c\right\rfloor+i\Big\lfloor\frac ac\Big\rfloor+\Big\lfloor\frac bc\Big\rfloor
\end{aligned}
\]
然后可以得到\(\varphi(a,b,c,n)=\varphi(a\bmod c,b\bmod c, c, n)+\frac {n(n+1)}2\lfloor\frac ac\rfloor+(n+1)\lfloor\frac bc\rfloor\)。
现在我们将\(\xi(i)\)的值限制在了\([0,n]\)之内,考虑将\(\varphi\)用新的式子表示出来:
\varphi(a,b,c,n)&=\sum_{i=0}^n\sum_{d=1}^{\lfloor\frac {an+b}c\rfloor}\left[\lfloor\frac {ai+b}c\rfloor\geq d\right]\\&=\sum_{i=0}^n\sum_{d=0}^{\lfloor\frac {an+b}c\rfloor-1}\left[a^{-1}c\lfloor\frac {ai+b}c\rfloor\geq a^{-1}c(d+1)>a^{-1}(cd+c-1)\right]\\&=\sum_{i=0}^n\sum_{d=0}^{\lfloor\frac {an+b}c\rfloor-1}\left[i>\frac {cd+c-b-1}{a}\right]
\end{aligned}
\]
而右边艾弗森括号里的相当于统计有多少个数大于\(\frac {cd+c-b-1}{a}\),就相当于\(n-\lfloor\frac {cd+c-b-1}{a}\rfloor\),那么
\varphi(a,b,c,n)&=\sum_{d=0}^{\lfloor\frac {an+b}c\rfloor-1}(n-\left\lfloor\frac {cd+c-b-1}{a}\right\rfloor)\\
&=n\left\lfloor\frac {an+b}c\right\rfloor-\sum_{d=0}^{\lfloor\frac {an+b}c\rfloor-1}\left\lfloor\frac {cd+c-b-1}{a}\right\rfloor\\
&=n\left\lfloor\frac {an+b}c\right\rfloor-\varphi(c,c-b-1,a,\left\lfloor\frac {an+b}c\right\rfloor-1)\\
&=n\left\lfloor\frac {an+b}c\right\rfloor-\varphi(c,c-b-1,a,\xi(n)-1)
\end{aligned}
\]
现在就可以递归处理了,至于复杂度,仔细思考一下发现和\(\gcd\)复杂度一样,为\(O(\log n)\)。
代码实现:
long long f(long long a, long long b, long long c, long long n) {
if (!a) return b / c * (n + 1);
else if (a >= c || b >= c) return f(a % c, b % c, c, n) + n * (n + 1) / 2 * (a / c) + (n + 1) * (b / c);
else {
long long m = (a * n + b) / c;
return n * m - f(c, c - b - 1, a, m - 1);
}
}
关于此题
\]
就是求\(y=\frac {c-ax}{b}\)下方或过直线在第一象限及正半轴上的整点数。
令\(n=\lfloor\frac ca\rfloor\),那么两端的点就为\((0,\frac cb),(n,\frac {c-an}b)\)。
显然可以把两端的\(y\)值调换一下,那么两点变为\((0,\frac {c-an}b),(n,\frac cb)\),
此时这条直线变为\(y=\frac ab x+\frac {c-an}{b}=\frac {ax+(c\;\bmod\;a)}b\),然后套到类欧的模板里再加上坐标轴上的贡献即可。
代码
#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <cmath>
#include <algorithm>
using namespace std;
long long a, b, c;
long long f(long long a, long long b, long long c, long long n) {
if (!a) return b / c * (n + 1);
else if (a >= c || b >= c) return f(a % c, b % c, c, n) + n * (n + 1) / 2 * (a / c) + (n + 1) * (b / c);
else {
long long m = (a * n + b) / c;
return n * m - f(c, c - b - 1, a, m - 1);
}
}
int main () {
#ifndef ONLINE_JUDGE
freopen("cpp.in", "r", stdin);
#endif
cin >> a >> b >> c;
printf("%lld\n", f(a, c % a, b, c / a) + c / a + 1);
return 0;
}
【LG5171】Earthquake的更多相关文章
- 【LuoguP5171】Earthquake
题目链接 题意 求满足如下不等式的非负整数 \(x,y\) 的对数 \[ax+by\leq c\] Sol a,b,c 都是非负的,那么先随便变个形: \[y\leq\frac{c-ax}{b}\] ...
- 【BZOJ】1585: [Usaco2009 Mar]Earthquake Damage 2 地震伤害
[题意]给定无向图,现在可能有一些点已经被删除,只给出信息是c个点未被删除且不能到达结点1,求最少的删除点个数. [算法]最小割 [题解]本题和1的区别是:1求的是最少的不能到达1的结点数,那么就把损 ...
- 【BZOJ1585】【Luogu2944】地震损失2(网络流)
[BZOJ1585][Luogu2944]地震损失2(网络流) 题面 题目描述 Wisconsin has had an earthquake that has struck Farmer John' ...
- Python高手之路【六】python基础之字符串格式化
Python的字符串格式化有两种方式: 百分号方式.format方式 百分号的方式相对来说比较老,而format方式则是比较先进的方式,企图替换古老的方式,目前两者并存.[PEP-3101] This ...
- 【原】谈谈对Objective-C中代理模式的误解
[原]谈谈对Objective-C中代理模式的误解 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 这篇文章主要是对代理模式和委托模式进行了对比,个人认为Objective ...
- 【原】FMDB源码阅读(三)
[原]FMDB源码阅读(三) 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 FMDB比较优秀的地方就在于对多线程的处理.所以这一篇主要是研究FMDB的多线程处理的实现.而 ...
- 【原】Android热更新开源项目Tinker源码解析系列之一:Dex热更新
[原]Android热更新开源项目Tinker源码解析系列之一:Dex热更新 Tinker是微信的第一个开源项目,主要用于安卓应用bug的热修复和功能的迭代. Tinker github地址:http ...
- 【调侃】IOC前世今生
前些天,参与了公司内部小组的一次技术交流,主要是针对<IOC与AOP>,本着学而时习之的态度及积极分享的精神,我就结合一个小故事来初浅地剖析一下我眼中的“IOC前世今生”,以方便初学者能更 ...
- Python高手之路【三】python基础之函数
基本数据类型补充: set 是一个无序且不重复的元素集合 class set(object): """ set() -> new empty set object ...
随机推荐
- 一文读懂前端技术演进:盘点Web前端20年的技术变迁史
本文原文由作者“司徒正美”发布于公众号“前端你别闹”,即时通讯网收录时有改动,感谢原作者的分享. 1.引言 1990 年,第一个Web浏览器的诞生:1991 年,WWW诞生,这标志着前端技术的开始. ...
- Autoware 1.12 安装/DEMO
前言 昨天试了一下新版本,发现完全按照官网安装会提示一些问题,所以留下记录. PS,我选择从源码安装Autoware 1.12 配置列表: 系统:Ubuntu 18.04 ROS:Melodic CU ...
- 阿里开源 KT Connnect,轻量级云原生测试环境治理平台来啦!
作者| 阿里云技术专家 郑云龙(砧木) 目前越来越多的开发者开始采纳 Kubernetes 管理基础设施环境,并通过 Kubernetes 完成日常的开发,测试以及生产发布活动,为了能够有效的帮助开发 ...
- Window权限维持(四):快捷方式修改
Windows快捷方式包含对系统上安装的软件或文件位置(网络或本地)的引用.自从恶意软件出现之初,便已将快捷方式用作执行恶意代码以实现持久性的一种方法.快捷方式的文件扩展名是.LNK,它为红队提供了很 ...
- 常用的排列、组合、阶乘函数 MATLAB
1.求n的阶乘,方法如下:a.factorial(n)b.gamma(n+1)c.v='n!'; vpa(v) 2.求组合(数),方法如下:a.combntns(x,m) 列举出从n个元素中取出 ...
- MySQL优化常见Extra分析——慢查询优化
数据准备: create table user ( id int primary key, name ), sex ), index(name) )engine=innodb; 数据说明:用户表:id ...
- sso单点登录的入门(Session跨域、Spring-Session共享)
1.单点登录,就是多系统,单一位置登录,实现多系统同时登录的一种技术.单点登录一般是用于互相授信的系统,实现单一位置登录,全系统有效的. 区分与三方登录(第三方登录) ,三方登录:某系统,使用其他系统 ...
- 纯 JS 设置文本框的默认提示
HTML5 中有个新特性叫 placeholder,一般用它来描述输入字段的预期值,适用于 text.search.password 等类型的 input 以及 textarea.示例如下: < ...
- Python - 模块 - 第十六天
Python 模块 在前面的几个章节中我们脚本上是用 python 解释器来编程,如果你从 Python 解释器退出再进入,那么你定义的所有的方法和变量就都消失了. 为此 Python 提供了一个办法 ...
- JS读取xml
xml文件 <?xml version="1.0" encoding="utf-8"?> <root> <data id=&quo ...