Задания
Версия для печати и копирования в MS Word
Тип Д6 № 36861
i

Из­вест­но, что при вводе не­ко­то­рых по­ло­жи­тель­ных зна­че­ний пе­ре­мен­ных s и x дан­ная про­грам­ма вы­во­дит число 17. Опре­де­ли­те, при каком наи­мень­шем введённом зна­че­нии пе­ре­мен­ной x это воз­мож­но. Для Ва­ше­го удоб­ства про­грам­ма пред­став­ле­на на четырёх язы­ках про­грам­ми­ро­ва­ния.

 

PythonСи++

s = int(input())

x = int(input())

s = 100*s + x

n = 1

while s < 2021:

    s = s + 5*n

    n = n + 1

print(n)

#include <iostream>

using namespace std;

int main()

{

    int s, x, n;

    cin >> s >> x;

    s = 100*s + x;

    n = 1;

    while (s < 2021) {

        s = s + 5*n;

        n = n + 1;

    }

    cout << n << endl;

    return 0;

}

Пас­кальАл­го­рит­ми­че­ский язык

var s, x, n: integer;

begin

    readln(s, x);

    s := 100*s + x;

    n := 1;

    while s < 2021 do begin

        s := s + 5*n;

        n := n + 1

    end;

    writeln(n)

end.

алг

нач

    цел s, x, n

    ввод s, x

    s := 100*s + x

    n := 1

    нц пока s < 2021

        s := s + 5*n

        n := n + 1

    кц

    вывод n, нс

кон

Спрятать решение

Ре­ше­ние.

Решим за­да­чу про­грамм­но ме­то­дом пе­ре­бо­ра. Ниже при­ве­де­на про­грам­ма на языке PascalABC:

var s, n, i, j: integer;

begin

for i := 1 to 1000 do begin

for j := 1 to 1000 do begin

n := 1;

s := i;

s := 100*s + j;

while s < 2021 do begin

s := s + 5*n;

n := n + 1

end;

if (n = 17) and (j <> 0) then begin

writeln(j);

break;

end;

end;

end;

end.

После вы­пол­не­ния про­грам­мы наи­мень­шее целое по­ло­жи­тель­ное число, вы­ве­ден­ное на экран, будет равно 1.

 

Ответ: 1.

 

При­ве­дем дру­гое ре­ше­ние.

Для того, чтобы про­грам­ма вы­ве­ла число 17, цикл дол­жен вы­пол­нить­ся 16 раз. За 15 ите­ра­ций цикла зна­че­ние пе­ре­мен­ной s уве­ли­чит­ся на 5 · (1 + 2 + ... + 15)  =  600, и для про­дол­же­ния цикла долж­но вы­пол­нять­ся усло­вие s + 600 < 2021. За 16 ите­ра­ций цикла зна­че­ние пе­ре­мен­ной s уве­ли­чит­ся на 5 · (1 + 2 + ... + 16)  =  680, и для за­вер­ше­ния цикла долж­но вы­пол­нять­ся усло­вие s + 680 ≥ 2021. Сле­до­ва­тель­но, перед на­ча­лом цикла зна­че­ние пе­ре­мен­ной s долж­но удо­вле­тво­рять усло­ви­ям 1341 ≤ s < 1421. Тогда ис­ход­но пе­ре­мен­ная s долж­на быть равна 13 или 14, но для того, чтобы пе­ре­мен­ная x была ми­ни­маль­ной, не­об­хо­ди­мо, чтобы s  =  14, тогда можно взять x  =  1.

 

При­ведём дру­гое ре­ше­ние на языке Python.

for i in range(1, 100):

s = i

for j in range(1, 100):

x = j

s = 100 * s + x

n = 1

while s < 2021:

s = s + 5 * n

n = n + 1

if n == 17:

print(j)

Раздел кодификатора ФИПИ: 1.7.2 Ос­нов­ные кон­струк­ции языка про­грам­ми­ро­ва­ния. Си­сте­ма про­грам­ми­ро­ва­ния