1 条题解
-
0
自动搬运
来自洛谷,原作者为

Thomas_Cat
越学越菜。搬运于
2025-08-24 22:27:35,当前版本为作者最后更新于2021-01-05 12:03:38,作者可能在搬运后再次修改,您可在原文处查看最新版自动搬运只会搬运当前题目点赞数最高的题解,您可前往洛谷题解查看更多
以下是正文
一些 wyy 的基础骗分的算法就不讲了,这里就简单的说说一个普通的算法:
solution:
对于 的数据,如果我们使用 的算法会 TLE ,现在给出一种算法:
对于一个数 来说,我们可以令该算法为 ,其实就是不断的相加: 加到一个 个位数 为止。(最后发现 的所有数字之和为 )。
因此我们只需要知道: ,因此只需要找出 (取整)的数量加上额外的数量即可。
注意因为本题数据范围 ,因此需要使用 。
代码如下:
#include <bits/stdc++.h> using namespace std; int main() { int n; cin>>n; while(n--) { long long l, r; cin>>l>>r; long long times=(r-l+1)/9;//周期统计的个数 long long sum=times*45; for(long long i=l+times*9;i<=r;i++)//计算从l之后的不完整周期的选择,注意在这里的数据是有规律可循的,因此 /9 即可 sum+=(i-1)%9+1; cout<<sum<<endl; } return 0; }复杂度为
- 1
信息
- ID
- 5863
- 时间
- 1000ms
- 内存
- 500MiB
- 难度
- 2
- 标签
- 递交数
- 0
- 已通过
- 0
- 上传者