プログラムの問題は次のとおりです。
フレンドリー番号:
「フレンドリー ナンバー」と呼ばれる特定の数字のペアがあります。定義上、フレンドリ数は 2 つの異なる数であり、その固有約数の合計はもう一方の数に等しくなります。
例: 友好的な数字の最小のペアは 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 は「フレンドリー ナンバー」と呼ばれます。フレンドリーな数字の最初の 2 ダースのペアを見つけて出力するプログラムを作成します。
友好的な番号のリストはここにあります。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 は 2 行前の右側の列に既に表示されています。
22) 180848 176272 23) 185368 203432 24) 196724 202444