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

Дано целое по­ло­жи­тель­ное число N. Не­об­хо­ди­мо найти наи­боль­шее ко­ли­че­ство под­ряд иду­щих нулей в де­ся­тич­ной за­пи­си N. На­при­мер, для N  =  2019 нужно по­лу­чить ответ 1, а для N  =  20100 ответ 2.

Для ре­ше­ния этой за­да­чи уче­ник на­пи­сал про­грам­му, но, к со­жа­ле­нию, его про­грам­ма не­пра­виль­ная.

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

 

Бей­сикPython

DIM N, M, K AS INTEGER

INPUT N

M = 0

K = 0

WHILE N >= 10

    IF N MOD 10 = 0 THEN

        K = K + 1

    ELSE

        K = 1

    END IF

    IF K > 0 THEN

        M = K

    END IF

    N = N \ 10

WEND

PRINT M

n = int(input())

m = 0

k = 0

while n>=10:

    if n % 10 == 0:

        k += 1

    else:

        k = 1

    if k > 0:

        m = k

    n //= 10

print(m)

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

var n, m, k: integer;

begin

    readln(n);

    m := 0;

    k := 0;

    while n >= 10 do begin

        if n mod 10 = 0

            then k := k + 1

        else k := 1;

        if k > 0 then

            m := k;

    n := n div 10;

    end;

    writeln(m)

end.

алг

нач

    цел n, m, k

    ввод n

    m := 0

    k := 0

    нц пока n >= 10

        если mod(n,10) = 0

            то k := k + 1

        иначе k := 1

        все

        если k > 0

            то m := k

        все

        n := div(n,10)

    кц

    вывод m

кон

С++

#include <iostream>

using namespace std;

int main() {

    int n, m, k;

    cin >> n;

    m = 0;

    k = 0;

    while (n >= 10) {

        if (n % 10 == 0)

            k += 1;

        else

            k = 1;

        if (k > 0)

            m = k;

        n /= 10;

    }

    cout << m;

    return 0;

}

 

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

 

1.  При­ве­ди­те при­мер числа N, при ко­то­ром про­грам­ма вы­ве­дет вер­ный ответ. Ука­жи­те этот ответ.

2.  При­ве­ди­те при­мер числа N, при ко­то­ром про­грам­ма вы­ве­дет не­вер­ный ответ. Ука­жи­те вер­ный ответ и ответ про­грам­мы.

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

 

До­ста­точ­но ука­зать ошиб­ки и спо­соб их ис­прав­ле­ния для од­но­го языка про­грам­ми­ро­ва­ния.

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

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

Ре­ше­ние.

1.  При­ме­ры чисел, при вводе ко­то­рых про­грам­ма вы­во­дит вер­ные от­ве­ты: 50 (ответ 1), 700 (ответ 2), 1000 (ответ 3).

2.  При­ме­ры чисел, при вводе ко­то­рых про­грам­ма вы­во­дит не­вер­ные от­ве­ты: 51 (пра­виль­ный ответ 0, про­грам­ма вы­во­дит 1), 701 (пра­виль­ный ответ 1, про­грам­ма вы­во­дит 2), 101 000 (пра­виль­ный ответ 3, про­грам­ма вы­во­дит 2).

3.  Про­грам­ма со­дер­жит две ошиб­ки.

1)  Не­вер­ный сброс счётчика нулей k. Из-за этой ошиб­ки длина це­поч­ки нулей, рас­по­ло­жен­ных не в конце числа, ока­зы­ва­ет­ся на еди­ни­цу боль­ше вер­ной.

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

Не яв­ля­ет­ся ошиб­кой усло­вие цикла. Про­вер­ка n>=10 вме­сто n>=1 при­во­дит к тому, что пер­вая цифра числа не про­ве­ря­ет­ся, но, по­сколь­ку ноль не может быть пер­вой циф­рой, это не вли­я­ет на пра­виль­ность от­ве­та.

 

При­мер ис­прав­ле­ния для языка Пас­каль:

 

Пер­вая ошиб­ка:

else k := 1;

Ис­прав­лен­ная стро­ка:

else k := 0;

 

Вто­рая ошиб­ка:

if k > 0 then

Ис­прав­лен­ная стро­ка, спо­соб 1:

if k > m then

Ис­прав­лен­ная стро­ка, спо­соб 2:

if k >= m then

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

Не­зна­чи­тель­ной опис­кой, не вли­я­ю­щей на оцен­ку, сле­ду­ет счи­тать от­сут­ствие зна­ков после со­дер­жа­тель­ной части ис­прав­ле­ния (на­при­мер, точки с за­пя­той в C++).

Спрятать критерии
Критерии проверки:

Кри­те­рии оце­ни­ва­ния вы­пол­не­ния за­да­нияБаллы
Вы­пол­не­ны все че­ты­ре не­об­хо­ди­мых дей­ствия, и ни одна вер­ная стро­ка не ука­за­на в ка­че­стве оши­боч­ной3
Не вы­пол­не­ны усло­вия, поз­во­ля­ю­щие по­ста­вить 3 балла. Имеет место одна из сле­ду­ю­щих си­ту­а­ций.

1. Вы­пол­не­ны три из четырёх не­об­хо­ди­мых дей­ствий, ни одна вер­ная стро­ка не на­зва­на оши­боч­ной.

2. Вы­пол­не­ны все че­ты­ре не­об­хо­ди­мых дей­ствия, одна вер­ная стро­ка на­зва­на оши­боч­ной.

2

Не вы­пол­не­ны усло­вия, поз­во­ля­ю­щие по­ста­вить 2 или 3 балла.

Вы­пол­не­ны два из четырёх не­об­хо­ди­мых дей­ствий.

1
Не вы­пол­не­ны усло­вия, поз­во­ля­ю­щие по­ста­вить 1, 2 или 3 балла. 0
Мак­си­маль­ный балл3