vijos1214——伤心的AsukaNoKaze

博主在vijos平台上遇到一道有趣的题目,通过打表发现解题规律:所有n/i相同的i,构成的n%i序列形成等差数列,公差为n/i。解决方案中,当i>sqrt(n)时,序列只剩一项,因此复杂度接近sqrt(n)。提醒读者在尝试解题时要思路清晰,避免错误。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

vijos1214
题目名字恕我实在不会读

刷作业累死来放松一下,刷到了这道挺有意思的题

以及这题我现在好像是跑最快的(优越感

其实是打表找规律。。当然如果您够强不打表也可以

输出暴力的各位n/i,n%i

这里写图片描述
可以发现,所有n/i相同的i,所构成的n%i序列,为一个公差=n/i的等差数列

然后我们就可以把所有n/i的值不止一个的数字全部一起处理出来,剩下的暴力求解

显然的是,当i>sqrt(n)时,只有一个

所以复杂度显然是接近sqrt(n)的

建议。。想清楚再打,不然很容易挂掉

比如那个等差数列的第一项是多少

#include<iostream>
#include<cstdio>
#include<cmath>
#include<algorithm>
#include<queue>
#include<string>
#include<map>
#include<cstring>
#include<vector>
#define inf 1e9
#define ll long long
#define For(i,j,k) for(ll i=j;i<=k;i++)
#define Dow(i,j,k) for(ll i=k;i>=j;i--)
using namespace std;
ll ans1,ans2;
int main()
{
    ll n;
    while(1)
    {
        scanf("%d",&n);
        if(n==0)    break;
        ans1=0,ans2=0;
        ll tot=0;
        For(i,1,sqrt(n)-1)
        {
            ll t=n/i-n/(i+1);

            tot+=t;
            ans1+=(i*(t-1)+2*(n%i))*t/2;
            ans2+=i*t; 
        }
        For(i,1,n-tot)
            ans1+=n%i,ans2+=n/i;
        printf("%lld %lld\n",ans2,ans1);
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值