Pagini recente » Cod sursa (job #19493) | Cod sursa (job #959703) | Cod sursa (job #1890730) | Cod sursa (job #2260988) | Cod sursa (job #1709067)
#include <fstream>
#include <vector>
#include <map>
#include <set>
#include <queue>
#include <cstring>
#include <string>
#include <algorithm>
#include <cmath>
#include <functional>
#include <utility>
#include <cstdio>
using namespace std;
int v[100000][2];
int main()
{
//ios_base::sync_with_stdio(false);
freopen("consecutive.in", "r", stdin);
freopen("consecutive.out", "w", stdout);
int t;
int k = 0;
unsigned n;
scanf("%d", &t);
while (t--){
scanf("%d", &n);
k = 0;
for (unsigned lg0 = 2, lg1 = 3; (lg0 % 2 ? lg0 * (lg1/2) : (lg0/2 * lg1)) <= n; ++lg0, ++lg1){
unsigned x = n - (lg0 % 2 ? lg0 * (lg1/2) : (lg0/2 * lg1));
if (x % lg0 == 0){
v[k][0] = x/lg0 + 1;
v[k][1] = x/lg0 + lg0;
++k;
}
}
printf("%d\n",k);
for (unsigned i = 0; i < k; ++i){
printf("%d %d\n",v[i][0], v[i][1]);
}
}
return 0;
}