Golubitskaya378
?>

Дан целочисленный массив из 20 элементов. элементы массива могут принимать целые числа от о до 10000 включительно. опишите на языке паскаль алгоритм, позволяющий найти и вывести максимальное значение среди трехзначных элементов массива, оканчивающихся на 0

Информатика

Ответы

olga0909196323
Var a: array [1..20] of integer; max,x,i: integer; begin randomize; writeln('массив: '); for i: = 1 to 20 do   begin   a[i]: =random(10001);   write(a[i]: 5);   end; writeln; for i: = 1 to 20 do   if a[i] div 100 > 0 then     if a[i] div 100 < 10 then     if a[i] mod 10 = 0 then      if x < a[i] then x: =a[i]; writeln('max: ',x); end. 
ivanrancev

В примере выше логическим выражением является n < 100. Если оно возвращает истину, то выполнится строчка кода b = n + a. Если логическое выражение ложно, то выражение b = n + a не выполнится.

Данный пример вырван из контекста и сам по-себе не является рабочим. Полная версия программы могла бы выглядеть так:

b = 0

a = 50

n = 98

if n < 100:

b = n + a

print(b)

Последняя строчка кода print(b) уже не относится к условному оператору, что обозначено отсутствием перед ней отступа. Она не является вложенной в условный оператор, значит, не принадлежит ему.

Поскольку переменная n равна 98, а это меньше 100, то b станет равной 148-ми. Это значение будет выведено на экран. Если переменная n изначально была бы связана, например, со значением 101, то на экран был бы выведен 0. При n, равной 101, логическое выражение в заголовке условного оператора вернуло бы ложь. Значит, тело не было бы выполнено, и переменная b не изменилась бы.

Структуру программы можно изобразить следующим образом:

Основная ветка программы выполняется всегда, а вложенный код лишь тогда, когда в темно-зеленой строчке, обозначающей заголовок условного оператора, случается истина.

Для небольших программ иногда чертят так называемые блок-схемы, отражающие алгоритм выполнения. В языке блок-схем определенные конструкции обозначаются своими фигурами. Так блок действий обозначается прямоугольником, а логическое выражение – ромбом. Для кода выше блок-схема может выглядеть так:

Блок-схема оператора if

Условный оператор может включать не одну ветку, а две, реализуя тем самым полноценное ветвление.

Блок-схема конструкции if-else

В случае возврата логическим выражением False поток выполнения программы не возвращается сразу в основную ветку. На случай False существует другой вложенный код, отличный от случая True. Другими словами, встретившись с расширенной версией условного оператора, поток выполнения программы не вернется в основную ветку, не выполнив хоть какой-нибудь вложенный код.

В языках программирования разделение на две ветви достигается с добавления блока else, получается так называемое if–else (если-иначе). Синтаксис выглядит примерно так:

if логическое_выражение {

выражение 1;

выражение 2;

}

else {

выражение 3;

}

Если условие при инструкции if оказывается ложным, то выполняется блок кода при инструкции else. Ситуация, при которой бы выполнились обе ветви, невозможна. Либо код, принадлежащий if, либо код, принадлежащий еlse. Никак иначе. В заголовке else никогда не бывает логического выражения.

Пример кода с веткой else на языке программирования Python:

tovar1 = 50

tovar2 = 32

if tovar1 + tovar2 > 99 :

print("99 рублей недостаточно")

else:

print("Чек оплачен")

Следует иметь в виду, что логическое выражение при if может выглядеть "нестандартно", т. е. не так просто, как a > b и тому подобное. Там может стоять просто одна переменная, число, слово True или False, а также сложное логическое выражение, когда два простых соединяются через логически И или ИЛИ.

a = ?

if a:

a = 1

Если вместо знака вопроса будет стоять 0, то с логической точки зрения это False, значит выражение в if не будет выполнено. Если a будет связано с любым другим числом, то оно будет расцениваться как True, и тело условного оператора выполнится. Другой пример:

a = 5 > 0

if a:

print(a)

Здесь a уже связана с булевым значением. В данном случае это True. Отметим, что в выражении a = 5 > 0 присваивание выполняется после оператора сравнения, так что подвыражение 5 > 0 выполнится первым, после чего его результат будет присвоен переменной a. На будущее, если вы сомневаетесь в последовательности выполнения операторов, используйте скобки, например так: a = (5 > 0).

Третий пример:

if a > 0 and a < b:

print(b - a)

Тут, чтобы вложенный код выполнился, a должно быть больше нуля и одновременно меньше b. Также в Питоне, в отличие от других языков программирования, позволительна такая сокращенная запись сложного логического выражения:

if 0 < a < b:

print(b - a)

Eduard Popik
А) 3  девочки могут сесть на 3 стула 6-ю разными способами и так же 3 мальчика могут сесть на 3 стула 6-ю способами арифметически эту закономерность можно записать как 1*2*3=6 6*6=36 способов всего. б) по той же закономерности получается 1*2*3*4*5=120 разных способов рассаживания отдельно мальчиков и отдельно девочек. всего способов: 120*120 = 14400 формулы  комбинаторики:   формула размещения с из n по m = n! /(n-m)! для размещения из 3 по 3 =  3! /(3-3)! =3! /1! =3! =1*2*3=6 для размещения из 5 по 5 = 5! /(5-5)! =5! /1! =5! =1*2*3*4*5=120

Ответить на вопрос

Поделитесь своими знаниями, ответьте на вопрос:

Дан целочисленный массив из 20 элементов. элементы массива могут принимать целые числа от о до 10000 включительно. опишите на языке паскаль алгоритм, позволяющий найти и вывести максимальное значение среди трехзначных элементов массива, оканчивающихся на 0
Ваше имя (никнейм)*
Email*
Комментарий*

Популярные вопросы в разделе

Sharap
agusarevich283
Zimin1111
ASRodichev
Nikol27051986
Маркина Ворошилина
ocik1632933
polikarpov-70
elmira01048775
dimoni86
Nadezhda Malakhov53
agent-ulitka5
buriginast5
info8
Чубкова1290