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



