В ПАСКАЛЕ Даны два натуральных числа a и b. Вывести a/b в виде периодической дроби....

0 голосов
25 просмотров

В ПАСКАЛЕ Даны два натуральных числа a и b. Вывести a/b в виде периодической дроби. Например: 1/3=0,(3)


Информатика (21 баллов) | 25 просмотров
0

Каждый год одни и те же задачи...

0

В каком смысле?

0

Ответ-то ты знаешь?)Просто хз как тут код написать

0

В прямом. Поиск тут есть

Дан 1 ответ
0 голосов
Правильный ответ

// PascalABC.NET 3.4.2, сборка 1797 от 22.09.2018

// Внимание! Если программа не работает, обновите версию!

function CycleFraction(a, b: integer): string;

begin

 Result := (a div b).ToString;

 a := a mod b;

 if a = 0 then exit;

 Result += ','; // разделитель

 var k := Result.Length + 1;

 var ost := new SortedList;

 ost.Add(a, k);

 while True do

 begin

   a *= 10;

   Result += (a div b).ToString;

   a := a mod b;

   if ost.ContainsKey(a) then

   begin

     var p := ost.Get(a);

     Result := Result?[:p] + (a <> 0 ? '(' + Result?[p:] + ')' : ''.ToString);

     exit

   end

   else

   begin

     k += 1;

     ost.Add(a, k);

   end

 end

end;


begin

 var (a, b) := ReadInteger2('Введите числитель и знаменатель:');

 CycleFraction(a, b).Println;

end.


image
(654k баллов)