Pagini recente » Cod sursa (job #1853058) | Cod sursa (job #3282293) | Cod sursa (job #2979050) | Cod sursa (job #1184609) | Cod sursa (job #1709436)
#include<iostream>
#include<fstream>
#include<algorithm>
#include<math.h>
using namespace std;
long long n,countt;
long long lower[100000], upper[100000];
int main(void){
ifstream fin("consecutive.in");
ofstream fout("consecutive.out");
int t;
fin>>t;
while(t--){
fin>>n;
countt=0;
long long tmp,b,k,a;
long long s =sqrt(2*n);
//cout<<s<<"\n";
for(k=1;k<s+5;k++){
if((2*n)%(k+1)==0){
tmp=2*n/(k+1)-k;
if(tmp%2==0&&tmp>0){
a=tmp/2;
b=a+k;
lower[countt]=a;
upper[countt]=b;
countt++;
}
}
}
fout<<countt<<"\n";
for(long long i=0;i<countt;i++)
fout<<lower[i]<<" "<<upper[i]<<"\n";
}
fout.close();
fin.close();
return 0;
}