洛谷P1147 连续自然数和

https://www.luogu.org/problem/P1147

#include<bits/stdc++.h>
using namespace std;
int main(){
    int n,sum;
    cin>>n;
    for(int i=1;i<=n/2;i++){   //m可能为奇数 
        for(int j=i+1;j<=n/2+1;j++){
            sum=(i+j)*(j-i+1)/2;
            if(sum==n) cout<<i<<" "<<j<<endl;
            if(sum>n) break;     //没有这一句会超时 
        }
    }
    return 0;
} 

 

posted @ 2019-10-22 11:13  晴屿  阅读(84)  评论(0编辑  收藏  举报