程序问题是这样的:
友好号码:
有些数字对被称为“友好数字”。根据定义,友好数字是两个不同的数字,其真除数之和等于另一个数字。
例如:最小的友好数字对是 220 和 284。220 的真因数是:1,2,4,5,10,11,20,22,24,44,55 和 110。这些的和除数为 284。
另一方面,284 的真除数是:1、2、4、71 和 142。这些除数的总和是 220。
因此,220 和 284 被称为“友好号码”。编写一个程序来查找并打印前两打友好的数字。
可以在此处找到友好号码列表。我正在尝试访问 80620 和 389924。
我的源代码在这里:
program Friendly Numbers;
type List=Array[1..50] of Integer;
var Num,Sum,Sum2,C,C2,C3,C4,CheckNum,LastNum:Integer;
NumUsed:String;
CheckedNum,CheckedSum:List;
begin
Num:=200;
while C3<=23 Do
begin
while C<Num Do
begin
C:=C+1;
if (C<>Num) and (Num mod C=0) then Sum:=Sum+C;
end;
while C2<Sum Do
begin
C2:=C2+1;
if (C2<>Sum) and (Sum mod C2=0) then Sum2:=Sum2+C2;
end;
if Num=Sum2 then
begin
for C4:=1 to 35 do
begin
if CheckedNum[C4]=C2 then NumUsed:='T';
if CheckedSum[C4]=Num then NumUsed:='T';
end;
if (C2<>LastNum) and (NumUsed<>'T') and (Num<>C2) then
begin
C3:=C3+1;
Writeln(C3,')',Num:8,C2:8);
LastNum:=Num;
end;
Checknum:=CheckNum+1;
CheckedNum[CheckNum]:=Num;
CheckedSum[CheckNum]:=C2;
end;
NumUsed:='F';
Num:=Num+1;
Sum:=0;
Sum2:=0;
C:=0;
C2:=0;
end;
Readln;
end.
输出:
1) 220 284 2) 1184 1210 3) 2620 2924 4) 5020 5564 5) 6232 6368 6) 10744 10856 7) 12285 14595 8) 17296 18416 9) 63020 76084 10) 66928 66992 11) 67095 71145 12) 69615 87633 13) 79750 88730 14) 100485 124155 15) 122265 139815 16) 122368 123152 17) 141664 153176 18) 142310 168730 19) 171856 176336 20) 176272 180848 21) 176336 171856
*176336 在前一行重复,而 176336 已经出现在右列前两行。
22) 180848 176272 23) 185368 203432 24) 196724 202444