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

Фак­то­ри­а­лом на­ту­раль­но­го числа N (обо­зна­ча­ет­ся N!) на­зы­ва­ет­ся про­из­ве­де­ние всех на­ту­раль­ных чисел от 1 до N. На­при­мер, 4!  =  1 · 2 · 3 · 4 = 24. Даны целые по­ло­жи­тель­ные числа A и B, 0 < AB. Не­об­хо­ди­мо найти ко­ли­че­ство таких на­ту­раль­ных K, для ко­то­рых AK! ≤ B. На­при­мер, при A = 5, B = 25 ответ дол­жен быть равен 2 (под­хо­дя­щие зна­че­ния K  — 3 и 4, их фак­то­ри­а­лы 6 и 24 по­па­да­ют в за­дан­ный ин­тер­вал). Для ре­ше­ния этой за­да­чи уче­ник на­пи­сал про­грам­му, но, к со­жа­ле­нию, его про­грам­ма не­пра­виль­ная. Ниже эта про­грам­ма для Ва­ше­го удоб­ства при­ве­де­на на пяти язы­ках про­грам­ми­ро­ва­ния.

 

Бей­сикPython

DIM A, B, K, F, D AS INTEGER

INPUT A: INPUT B

F = 1

K = 0

D = 0

WHILE F < B

    IF F >=A THEN

        D = D + 1

    END IF

    K = K + 1

    F = F * K

WEND

PRINT D

END

a = int(input())

b = int(input())

f = 1

k = 0

d = 0

while f < b:

    if f >= a:

        d += 1

    k += 1

    f *= k

print(d)

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

var a, b, k, f, d: integer;

begin

    read(a, b);

    f := 1;

    k := 0;

    d := 0;

    while f < b do begin

        if f >= a then

            d := d + 1;

        k := k + 1;

        f := f * k

    end;

    writeln(d)

end.

алг

нач

    цел a, b, k, f, d

    ввод a, b

    f := 1

    k := 0

    d := 0

    нц пока f < b

        если f >=a

            то d := d + 1

        все

        k := k + 1

        f := f * k

    кц

    вывод d

кон

С++

#include <iostream>

using namespace std;

int main(){

    int a, b, k, f, d;

    cin >> a >> b;

    f = 1;

    k = 0;

    d = 0;

    while (f < b) {

        if (f >= a)

            ++d;

        ++k;

        f *= k;

    }

    cout << d;

    return 0;

}

 

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

1.  На­пи­ши­те, что вы­ве­дет эта про­грам­ма при вводе чисел 2 и 6.

2.  При­ве­ди­те при­мер вход­ных дан­ных, при ко­то­рых про­грам­ма вы­ве­дет ответ, ко­то­рый боль­ше пра­виль­но­го.

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

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

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

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

Ре­ше­ние.

1.  При вводе чисел 2 и 6 про­грам­ма вы­ве­дет число 1.

2.  Ответ боль­ше пра­виль­но­го по­лу­ча­ет­ся, если пер­вое число равно 1, а вто­рое не яв­ля­ет­ся точ­ным фак­то­ри­а­лом. На­при­мер, 1 и 3, 1 и 4. Уче­ни­ку до­ста­точ­но при­ве­сти одну кон­крет­ную пару чисел.

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

1)  Не­вер­ная ини­ци­а­ли­за­ция «ос­но­ва­ния» фак­то­ри­а­ла K. Из-за этого зна­че­ние 1 фак­то­ри­а­ла F про­ве­ря­ет­ся два­жды, и если A = 1, к от­ве­ту при­бав­ля­ет­ся лиш­няя еди­ни­ца.

2)  Оши­боч­ное срав­не­ние. Вме­сто не­стро­го­го срав­не­ния F и B вы­пол­ня­ет­ся стро­гое. Из-за этого в тех слу­ча­ях, когда B ока­зы­ва­ет­ся точ­ным фак­то­ри­а­лом, ответ по­лу­ча­ет­ся на еди­ни­цу мень­ше

 

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

 

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

k := 0;

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

k := 1;

 

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

while f < b do begin

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

while f <= b do begin

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

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

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

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

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

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

2

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

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

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