Pascal abc.net - модули даны два массива натуральных чисел. в одном из них числа записаны в десятичной системе счисления, в другом — в римской. выписать числа, которые встречаются и в том, и в другом массиве, или сообщить об их отсутствии. в случае положительного ответа результат представить в римской и десятичной системах счисления. решить с использованием модулей подпрограмм (или несколько подпрограмм), а потом обратиться из своей программы к этому модулю , завтра последний день ! )
280
445
Ответы на вопрос:
Решение в pascalabc.net 3.4 *** этот файл мы должны назвать nekkit20.pas *** *** после его компиляции будет создан модуль *** unit nekkit20; type tra=(string,integer); function rometoarab(s: string): integer; // перевод римских чисел (не больших mmmcmxcix) в арабские begin var ar: ='ivxlcdm'; var aa: =arr(1,5,10,50,100,500,1000); var n: =0; result: =0; foreach var c in s do begin var c1: =n; n: =aa[pos(c,ar)-1]; result+=n+(n> c1? -2*c1: 0) end; end; function equal(r: array of string; a: array of integer): sequence of tra; // возвращает последовательность кортежей // из массива римских чисел (массив r), // для которых есть соответствие в массиве арабских чисел (массив a) begin foreach var q in r do begin var n: =rometoarab(q); if a.indexof(n)> -1 then yield((q,n)) end end; end. *** а это другой файл с любым именем, кроме nekkit20 *** *** он обращается к молулю nekkit20 *** uses nekkit20; begin var sr: =arr('dxviii','lxiii','mii','xiv','lxxxviii','cxcvi'); var ar: =arr(14,98,196,1002,518,64,87); var r: =equal(sr,ar); if r.count=-1 then writeln('нет совпадений') else foreach var t in r do writeln(t[0],' = ',t[1]) end. *** контрольный пример *** dxviii = 518 mii = 1002 xiv = 14 cxcvi = 196
Популярно: Информатика
-
sweetk08.04.2021 18:21
-
Ivan19090112.09.2021 19:33
-
shamilsaidov201.09.2022 06:26
-
Ирочка30020.04.2020 20:05
-
massenia14.12.2020 23:44
-
Criss66618.09.2020 16:50
-
Nuruk0426.05.2022 15:33
-
udovilyudmila30.12.2021 12:37
-
lailylaily05.02.2023 16:51
-
dimabarabanov06.01.2022 09:50