余数求和

题目链接

https://www.luogu.com.cn/problem/P2261

解题思路

整除分块基础
大佬写的太好了
图片说明

AC代码

#include<bits/stdc++.h>
#define ll long long
using namespace std;
ll ans,n,k;
int main()
{
    cin>>n>>k;
    ans=n*k;
    for(ll l=1,r;l<=n;l=r+1)
    {
        if(k/l!=0) r=min(k/(k/l),n); 
        else r=n;
        ans-=(l+r)*(r-l+1)*(k/l)/2;
    }
    cout<<ans<<endl;
    return 0;
}
全部评论

相关推荐

09-21 21:14
门头沟学院
否极泰来来来来:和他说:这里不好骂你,我们加个微信聊
点赞 评论 收藏
分享
评论
2
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务