Версия для копирования в MS Word
PDF-версии: горизонтальная · вертикальная · крупный шрифт · с большим полем
РЕШУ ЕГЭ — информатика
Задания
i

Дано целое по­ло­жи­тель­ное число N. Не­об­хо­ди­мо найти и вы­ве­сти ко­ли­че­ство и сумму цифр, крат­ных 3, в де­ся­тич­ной за­пи­си N. Если крат­ных 3 цифр в числе нет, нужно вы­ве­сти слово «NO». На­при­мер, для N  =  1960 нужно вы­ве­сти числа 3 (в числе три крат­ные 3 цифры) и 15 (9 + 6 + 0 = 15), а для N = 1812  — слово «NO» Для ре­ше­ния этой за­да­чи уче­ник на­пи­сал про­грам­му, но, к со­жа­ле­нию, его про­грам­ма не­пра­виль­ная.

Ниже эта про­грам­ма для Ва­ше­го удоб­ства при­ве­де­на на пяти язы­ках про­грам­ми­ро­ва­ния.

Бей­сикPython

DIM N, D, K, S AS INTEGER

INPUT N

K = 0

S = 0

WHILE N > 10

    D = N MOD 10

    IF D MOD 3 = 0 THEN

        K = K + 1

        S = S + D

    END IF

    N = N \ 10;

WEND

IF S > 0 THEN

    PRINT K, S

ELSE

    PRINT "NO"

END IF

n = int(input())

k = 0

s = 0

while n>10:

    d = n % 10

    if d % 3 == 0:

        k += 1

        s = s + d

    n = n // 10

if s > 0:

    print(k,s)

else:

    print("NO")

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

var n, d, k, s: integer;

begin

    readln(n);

    k := 0;

    s := 0;

    while n > 10 do begin

        d := n mod 10;

        if d mod 3 = 0 then begin

            k := k + 1;

            s := s + d

        end;

        n := n div 10

    end;

    if s > 0 then

        write(k, ' ', s)

    else

        write('NO')

end.

алг

нач

    цел n, d, k, s

    ввод n

    k := 0

    s := 0

    нц пока n > 10

        d := mod(n,10)

        если mod(d,3)=0 то

            k := k + 1

            s := s + d

        все

        n := div(n,10)

    кц

    если s > 0 то

        вывод k, ' ', s

    иначе

        вывод "NO"

    все

кон

Си++

#include <iostream>

using namespace std;

 

int main() {

    int n, d, k, s;

    cin >> n;

    k = 0;

    s = 0;

    while (n > 10) {

        d = n % 10;

        if (d % 3 == 0) {

            ++k;

            s = s + d;

        }

        n /= 10;

    }

    if (s > 0)

        cout << k << ' ' << s;

    else

        cout << "NO";

    return 0;

}

По­сле­до­ва­тель­но вы­пол­ни­те сле­ду­ю­щее.

1.  На­пи­ши­те, что вы­ве­дет эта про­грам­ма при вводе N  =  3961.

2.  При­ве­ди­те при­мер трёхзнач­но­го числа N, со­дер­жа­ще­го хотя бы одну крат­ную 3 цифру, при вводе ко­то­ро­го про­грам­ма вы­ве­дет вер­ный ответ.

3.  Най­ди­те в про­грам­ме все ошиб­ки (из­вест­но, что их не боль­ше двух) и ис­правь­те их. Для каж­дой ошиб­ки вы­пи­ши­те стро­ку, в ко­то­рой она до­пу­ще­на, и при­ве­ди­те эту же стро­ку в ис­прав­лен­ном виде.