p2261 [CQOI2007]余数求和

Posted yzxverygood

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了p2261 [CQOI2007]余数求和相关的知识,希望对你有一定的参考价值。

传送门

分析

https://zzlzk.blog.luogu.org/solution-p2261

代码

#include<iostream>
#include<cstdio>
#include<cstring>
#include<string>
#include<algorithm>
#include<cctype>
#include<cmath>
#include<cstdlib>
#include<queue>
#include<ctime>
#include<vector>
#include<set>
#include<map>
#include<stack>
using namespace std;
int main(){
    long long Ans,n,k,le=1,ri;
    scanf("%lld%lld",&n,&k);
    Ans=n*k;
    for(;le<=n;le=ri+1){
      if(k/le)ri=min(n,k/(k/le));
        else ri=n;
      Ans-=(k/le)*((ri-le+1)*(ri+le)/2);
    }
    cout<<Ans;
    return 0;
}

以上是关于p2261 [CQOI2007]余数求和的主要内容,如果未能解决你的问题,请参考以下文章

题解 P2261 [CQOI2007]余数求和

P2261 [CQOI2007]余数求和

P2261 [CQOI2007]余数求和

P2261 [CQOI2007]余数求和

P2261 [CQOI2007]余数求和

洛谷P2261[CQOI2007]余数求和