Втаблице dat хранится положительные или отрицательные целые числа. определите, что будет напечатано в результате работы следующей программыю. текст программы на пяти языках программирования. паскаль var k, m: integer; dat: array[1..10] of integer; begin dat[1]: = -5; dat[2]: = 4; dat[3]: =
-3; dat[4]: = 2; dat[5]: = 7; dat[6]: = -1; dat[7]: = 9; dat[8]: = 8; dat[9]: = 7; dat[10]: = 4; m: = 0; for k: = 1 to 10 do begin if dat[k]*m < 20 then begin m: = dat[k] end; wrieln(m); end.
Для данной сортировки используем алгоритм сортировки слиянием
В начале разбиваем арбузы на 2 группы по 2Каждую группу взвешиваем и сортируем (т.е. всего 2 взвешивания)Теперь собираем вместе, сравниваем сначала более легкие арбузы и находим самый легкий (всего 3 взвешивания)Теперь сравниваем тяжелый арбуз, что в группе с самым легким и более легкий из другой группы, и определяем второй по легкости (всего 4 взвешивания)Потом взвешиваем оставшиеся арбузы и докладываем их по порядку (всего 5 взвешивания)ответ:
. в нужно вывести все составные числа из промежутка [2; n]. код программы:
program lab3;
var i,n,j,s,l: integer;
m: real;
begin
readln (n);
for i: =2 to n do
begin
s: =trunc (sqrt (i));
for l: =2 to s do
begin
m: = i mod l;
if m=0 then
write (' ',i);
end;
end;
end.
но проблема - как только s становится больше 2, составные числа начинают несколько раз повторятся, т.к., например 12 делится и на 2 и на 3. вопрос: как мне сделать выход из цикла после первого успешного деления?
var
i, n, j, s, l: integer;
m: real;
begin
readln(n);
for i : = 2 to n do
begin
s : = trunc(sqrt(i));
for l : = 2 to s do
begin
m : = i mod l;
if m = 0 then
begin
write(' ', i);
break;