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

Фак­то­ри­а­лом на­ту­раль­но­го числа n (обо­зна­ча­ет­ся n!) на­зы­ва­ет­ся про­из­ве­де­ние всех на­ту­раль­ных чисел от 1 до n. На­при­мер, 4!  =  1 · 2 · 3 · 4  =  24.

Дано целое по­ло­жи­тель­ное число A. Не­об­хо­ди­мо найти бли­жай­шее к A число, ко­то­рое яв­ля­ет­ся точ­ным фак­то­ри­а­лом ка­ко­го-либо на­ту­раль­но­го числа. Если два точ­ных фак­то­ри­а­ла оди­на­ко­во близ­ки к A, нужно вы­брать мень­ший из них. На­при­мер, для A = 15 нужно по­лу­чить ответ 6, а для A = 20 – ответ 24.

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

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

 

Бей­сикPython

DIM A, K, F AS INTEGER

INPUT A

K = 1

F = 1

WHILE F < A

    K = K + 1

    F = F * K

WEND

IF F − A >= F \ K − A THEN

    F = F \ K

END IF

PRINT K

END

a = int(input())

k = 1

f = 1

while f < a:

    k += 1

    f *= k

if f − a >= f // k − a:

    f //= k

print(k)

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

var a, k, f: integer;

begin

    read(a);

    k := 1;

    f := 1;

    while f < a do begin

        k := k + 1;

        f := f * k

    end;

    end;

    if f−a >= f div k − a

        then f := f div k;

    writeln(k)

end.

алг

нач

    цел a, k, f

    ввод a

    k := 1

    f := 1

    нц пока f < a

        k := k + 1

        f := f * k

    кц

    если f − a >= div(f,k) − a

        то f := div(f,k)

    все

    вывод k

кон

С++

#include <iostream>

using namespace std;

int main(){

    int a, k, f;

    cin >> a;

    k = 1;

    f = 1;

    while (f < a) {

        ++k;

        f *= k;

    }

    if (f − a >= f/k − a)

        f = f/k;

    cout << k;

    return 0;

}

 

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

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

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

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

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

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

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

Ре­ше­ние.

1.  При вводе A = 5 про­грам­ма вы­ве­дет число 3.

2.  Про­грам­ма вы­во­дит вер­ный ответ при вводе A = 1 (ответ 1) или A = 2 (ответ 2).

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

1)  Оши­боч­ная про­вер­ка. После за­вер­ше­ния цикла га­ран­ти­ро­ван­но вы­пол­ня­ет­ся не­ра­вен­ство F ≥ A > F/A, по­это­му в срав­не­нии после цикла левая часть все­гда не­от­ри­ца­тель­на, а пра­вая  — от­ри­ца­тель­на. Срав­не­ние ока­зы­ва­ет­ся все­гда вер­ным, в ре­зуль­та­те вы­би­ра­ет­ся не бли­жай­ший к A точ­ный фак­то­ри­ал, а бли­жай­ший, не пре­вос­хо­дя­щий A.

2)  Оши­боч­ный вывод. Вме­сто зна­че­ния фак­то­ри­а­ла F вы­во­дит­ся «ос­но­ва­ние» фак­то­ри­а­ла K.

 

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

 

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

if f − a >= f div k − a

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

if f − a >= a − f div k

Воз­мож­но также ис­поль­зо­ва­ние функ­ции abs (мо­дуль числа):

if f − a >= abs(f div k − a)

 

Функ­цию abs можно ис­поль­зо­вать и в левой части срав­не­ния. Это ни­че­го не ме­ня­ет по сути, так как левая часть за­ве­до­мо не­от­ри­ца­тель­на, но такое ис­поль­зо­ва­ние нель­зя счи­тать ошиб­кой:

 

if abs(f − a) >= abs(f div k − a)

 

При ис­поль­зо­ва­нии мо­ду­ля для ис­прав­ле­нии фраг­мен­та на ал­го­рит­ми­че­ском языке сле­ду­ет ис­поль­зо­вать функ­цию iabs (мо­дуль для целых чисел):

 

если f − a >= iabs(div(f,k) − a)

 

Ис­поль­зо­ва­ние в ал­го­рит­ми­че­ском языке функ­ции abs вме­сто iabs от­ме­ча­ет­ся как ошиб­ка, но не вли­я­ет на оцен­ку ра­бо­ты.

 

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

writeln(k)

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

writeln(f)

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

Не­зна­чи­тель­ной опис­кой, не вли­я­ю­щей на оцен­ку, сле­ду­ет счи­тать от­сут­ствие слу­жеб­ных слов и зна­ков после со­дер­жа­тель­ной части ис­прав­ле­ния.

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

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

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

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

2

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

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

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