給出乙個整數n,將n表示為2個整數i j的平方和(i <= j),如果有多種表示,按照i的遞增序輸出。
例如:n = 130,130 = 3^2 + 11^2 = 7^2 + 9^2 (注:3 11同11 3算1種)
input
乙個數n(1 <= n <= 10^9)
output
共k行:每行2個數,i j,表示n = i^2 + j^2(0 <= i <= j)。
如果無法分解為2個數的平方和,則輸出no solution
input示例
130
output示例
3 11
7 9
#include"cstdio"
#include"algorithm"
#include"cmath"
using namespace std;
int main()
}if(flag==0)
printf("no solution\n");
return
0; }
如果直接用兩個變數不斷的去湊,看是不是平方和,肯定是要tl的,兩個優化的點,乙個是判定到根號n,就可以了。另乙個是,減去其中乙個的平方和,看看差是不是乙個平方數就可以了。 51nod 1080 兩個數的平方和
1080 兩個數的平方和 基準時間限制 1 秒 空間限制 131072 kb 分值 5 難度 1級演算法題 給出乙個整數n,將n表示為2個整數i j的平方和 i j 如果有多種表示,按照i的遞增序輸出。例如 n 130,130 3 2 11 2 7 2 9 2 注 3 11同11 3算1種 inpu...
51nod1080 兩個數的平方和
給出乙個整數n,將n表示為2個整數i j的平方和 i j 如果有多種表示,按照i的遞增序輸出。例如 n 130,130 3 2 11 2 7 2 9 2 注 3 11同11 3算1種 input 乙個數n 1 n 10 9 output 共k行 每行2個數,i j,表示n i 2 j 2 0 i j...
51nod1080 兩個數的平方和
給出乙個整數n,將n表示為2個整數i j的平方和 i j 如果有多種表示,按照i的遞增序輸出。例如 n 130,130 3 2 11 2 7 2 9 2 注 3 11同11 3算1種 input 乙個數n 1 n 10 9 output 共k行 每行2個數,i j,表示n i 2 j 2 0 i j...