Ниже приведена программа, записанная на пяти языках программирования.
| Бейсик | Python |
|---|---|
DIM s, t AS INTEGER INPUT s INPUT t IF s > 8 OR t > 8 THEN PRINT ‘YES’ ELSE PRINT ‘NO’ ENDIF | s = int(input()) t = int(input()) if s > 8 or t > 8: print("YES") else: print("NO")
|
| Паскаль | Алгоритмический язык |
var s, t: integer; begin readln(s); readln(t); if (s > 8) or (t > 8) then writeln('YES') else writeln('NO') end.
| алг нач цел s, t ввод s ввод t если s > 8 или t > 8 то вывод "YES" иначе вывод "NO" все кон |
| С++ | |
#include <iostream> using namespace std; int main() { int s, t; cin >> s; cin >> t; if (s > 8 || t > 8) cout << "YES"; else cout << "NO"; return 0; } | |
Было проведено 9 запусков программы, при которых в качестве значений переменных s и t вводились следующие пары чисел:
(8, 8); (9, 6); (4, 7); (6, 6); (–9, –2); (–5, 9); (–10, 10); (6, 9); (10, 6).
Сколько было запусков, при которых программа напечатала «NO»?
Заметим, что программа напечатает «NO», если обе введенные переменные s и t будут меньше или равны 8. Значит, было 4 запуска, при которых программа напечатала «NO». В качестве значений переменных s и t в этих случаях вводились следующие пары чисел:
(8, 8); (4, 7); (6, 6); (–9, –2).
Ответ: 4.
Примечание.
Другой способ решения и правила замены логических условий на противоположные приведены в задании 10955.
Приведем другое решение на языке Python.
def f(s, t):
if s > 8 or t > 8:
return 0
else:
return 1
a = ((8, 8), (9, 6), (4, 7), (6, 6), (-9, -2), (-5, 9), (-10, 10), (6, 9), (10, 6))
kol = 0
for i in range(9):
kol += f(a[i][0], a[i][1])
print(kol)



