noi 親密數對
#include <bits/stdc++.h> using namespace std; void y(int a,int b,int c){ for(int k=3;k<=a;k++){ b=0,c=0; for(int m=2;m<=k/2;m++){ if(k%m==0){ b+=m; } } for(int j=2;j<=b/2;j++){ if(b%j==0){ c+=j; } } if(c==k&&b<a){ cout<<c<<" "<<b<<endl; } /* if(b>k||c>k){ }*/ } } int main() { int a,b=0,c=0; cin>>a; y(a,b,c); return 0; }
鍵盤輸入N,N在2至2000之間,求2至N中的親密數對,就是A的因子和等于B,B的因子和等于A,且A≠B。 如48和75是親密數對。48的因子和為2+3+4+6+8+12+16+24=75,而75的因子和為3+5+15+25=48。
輸入描述
只有一行,為一個整數N( 2<=N<=2000 )
輸出描述
輸出若干行,每行兩個整數(用一個空格隔開)。
用例輸入 1
200
用例輸出 1
48 75 75 48 140 195 195 140

浙公網安備 33010602011771號