Codeforces.468C.Hack it!(构造)
\(dls\)出的比赛诶...这么妙。
\(Description\)
令\(f(x)\)表示整数\(x\)在十进制下各个数位的数字之和。给定\(a\),求两个整数\(l,r\),使得\(\sum_{i=l}^rf(i)\equiv0\ (\mathbb{mod}\ a)\)。
\(1\leq a\leq10^{18},\ 1\leq l\leq r\leq10^{200}\),保证存在解。
\(Solution\)
考虑一个简单的性质:\(f(x+10^y)=f(x)+1,\ x\lt10^y\)。
不妨令\(INF=10^{18}\),设\(\sum\limits_{i=0}^{INF-1}f(i)\equiv p\ (\mathbb{mod}\ a)\)。
由上面的性质可知,\(\sum\limits_{i=1}^{INF}f(i)=p-f(0)+f(INF)=p+1\)。
同理还有:\(\sum\limits_{i=2}^{INF+1}f(i)=p+2...\ \sum\limits_{i=k}^{INF+k-1}f(i)=p+k\)(都是模\(a\)意义下)。
然后就可以构造出\(a=p+a-p=\sum\limits_{i=a-p}^{INF+a-p-1}f(i)\)。所以令\(l=a-p,\ r=10^{18}+a-p-1\)就可以啦。
有个问题是求\(\sum_{i=0}^{10^{18}-1}f(i)\ \mathbb{mod}\ a\)。展开一下:$$\begin{aligned}\sum_{i=0}{10{18}-1}f(i)&=(1+2+...+9)10{17}+10\times\sum_{i=0}{10{17}-1}f(i)\&=45\times10{17}+10(45\times10{16}+10\times\sum_{i=0}{10{15}-1}f(i))\&=...\&=18\times45\times10{17}=81\times10^{18}\end{aligned}$$
这样就做完啦。
还有个做法是,考虑有\(\sum\limits_{i=1+x}^{10^y+x}f(i)-\sum\limits_{i=1}^{10^y}f(i)=x,\ x\lt10^y\)。枚举\(y\),如果有\(a-\sum\limits_{i=0}^{10^y}<10^y\),令\(x\)等于这个数,就有\(\sum\limits_{i=1+x}^{10^y+x}f(i)=\sum\limits_{i=0}^{10^y}+a-\sum\limits_{i=0}^{10^y}=a\)了。
需要预处理一下\(\sum_{i=1}^{10^y}f(i)\),因为是上限\(10\)的幂所以算一下每个数出现次数即可(或者像上面一样直接算)。
#include <cstdio>
typedef long long LL;
const LL INF=1e18;
int main()
{
LL a; scanf("%I64d",&a);
LL l=a-INF*9%a*9%a;
printf("%I64d %I64d\n",l,INF+l-1);
return 0;
}
Codeforces.468C.Hack it!(构造)的更多相关文章
- Codeforces 468C Hack it!
https://www.luogu.org/problemnew/show/CF468C http://codeforces.com/contest/468/problem/C #include &l ...
- 「Codeforces 468C」Hack it!
Description 定义 \(f(x)\) 表示 \(x\) 的各个数位之和.现在要求 \(\sum_{i=l}^rf(i)\bmod a\). 显然 ans=solve(l,r)%a; if(a ...
- Codeforces 1383D - Rearrange(构造)
Codeforces 题面传送门 & 洛谷题面传送门 一道不算困难的构造,花了一节英语课把它搞出来了,题解简单写写吧( 考虑从大往小加数,显然第三个条件可以被翻译为,每次加入一个元素,如果它所 ...
- Codeforces 549B. Looksery Party[构造]
B. Looksery Party time limit per test 1 second memory limit per test 256 megabytes input standard in ...
- codeforces 323A. Black-and-White Cube 构造
输入n 1 <= n <= 100 有一个n * n * n 的立方体,由n ^ 3 个1 * 1 * 1 的单位立方体构成 要用white 和 black 2种颜色来染这n ^ 3个立方 ...
- Codeforces Gym 100531I Instruction 构造
Problem I. Instruction 题目连接: http://codeforces.com/gym/100531/attachments Description Ingrid is a he ...
- codeforces 22C System Administrator(构造水题)
转载请注明出处: http://www.cnblogs.com/fraud/ ——by fraud System Administrator Bob got a job as a s ...
- Codeforces 353D Queue(构造法)
[题目链接] http://codeforces.com/contest/353/problem/D [题目大意] 10^6个男女排队,每一秒,如果男生在女生前面,即pos[i]是男生,pos[i+1 ...
- Codeforces 482 - Diverse Permutation 构造题
这是一道蛮基础的构造题. - k +(k - 1) -(k - 2) 1 + k , 1 , k , 2, ....... ...
随机推荐
- 微信小程序 如何获取用户code
1.首先需要获取code 使用 wx.login({ success: function(res) { console.log(res);//这里的返回值里面便包含code }, fail: func ...
- 008-Python-模块
1.模块 1.1什么是模块 一个模块就是一个包含了python定义和声明的文件,文件名就是模块名字加上.py的后缀: 模块分为: 内置模块(内部定义的如time,os,sys等) 第三方模块(需要安装 ...
- node.js(一)
安装官网: https://nodejs.org/en/ 运行代码: var http=require('http') http.createServer(function(req,res){ res ...
- jQuery实用工具集
插件描述:jQuery实用工具集,该插件封装了常用功能,如序列化表单值获取地址栏参数window对象操作等 此工具集包含判断浏览器,判断浏览终端,获取地址栏参数,获取随机数,数据校验等常用操作功能 引 ...
- jQuery中的extend()方法
通常我们使用jquery的extend时,大都是为了实现默认字段的覆盖,即若传入某个字段的值,则使用传入值,否则使用默认值.如下面的代码: function getOpt(option){ var _ ...
- (转载)C#压缩解压zip 文件
转载之: C#压缩解压zip 文件 - 大气象 - 博客园http://www.cnblogs.com/greatverve/archive/2011/12/27/csharp-zip.html C# ...
- ubuntu安装php+mysql+apche
步骤一,安装apache2 ? sudo apt-get install apache2 安装完成. 运行如下命令重启下: ? sudo /etc/init.d/apache2 restart 在浏览 ...
- [转]Ubuntu /home下中文目录如何修改成英文?
http://www.linuxidc.com/Linux/2016-05/130873.htm 打开终端,在终端中输入命令: export LANG=en_US xdg-user-dirs-gtk- ...
- 开源CMS系统Moodle对比中国本土化开源在线教育平台EduSoho
这段时间研究了一下著名的开源课程管理系统Moodle,也了解了一下目前国内比较火的在线教育平台EduSoho,发现二者有诸多相似之处,但优势各异.接下来就简单对着两个平台做一下对比. 首先来说一下Ed ...
- libsecp256k1 与 openssl ecdsa
1. 历史 区块链节点在接收到的用户发送的交易时,首先会验证交易所涉及utxo的可用性.方法是验证用户签名的合法性,涉及的签名算法就是secp256k1,一种椭圆曲线加密算法. 长期以来,实现了该算法 ...