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

Дано на­ту­раль­ное число A. Тре­бу­ет­ся вы­ве­сти такое ми­ни­маль­но воз­мож­ное на­ту­раль­ное число K, при ко­то­ром сумма 1 + (1 + 2) + (1 + 2 + 3) + … + (1 + 2 + … + K) не пре­вы­ша­ет A. Для ре­ше­ния этой за­да­чи уче­ник на­пи­сал про­грам­му, но, к со­жа­ле­нию, его про­грам­ма – не­пра­виль­ная. Ниже эта про­грам­ма для Ва­ше­го удоб­ства при­ве­де­на на пяти язы­ках про­грам­ми­ро­ва­ния.

Бей­сикPython

DIM A,S,P,K AS INTEGER

INPUT A

S = 0

P = 1

K = 1

WHILE S <= A

    K = K + 1

    P = P + K

    S = S + P

WEND

PRINT K

END

a = int(input())

s = 0

p = 1

k = 1

while s <= a:

     k = k + 1

     p = p + k

     s = s + p

print(k)

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

var a, s, p, k: integer;

begin

    readln(a);

    s := 0;

    p := 1;

    k := 1;

    while s <= a do begin

      k := k+1;

      p := k+p;

      s := p+s;

    end;

    writeln(k);

end.

алг

нач

   цел a, s, p, k

   ввод a

   s := 0

   p := 1

   k := 1

   нц пока s <= a

     k := k+1

     p := p+k

     s := s+p

   кц

  вывод k

кон

Си++

#include <iostream>

using namespace std;

int main()

{

   int a, s, p, k;

   cin >> a;

   s = 0;

   p = 1;

   k = 1;

   while (s <= a) {

       k = k+1;

       p = p+k;

       s = s+p;

   }

   cout « k « endl;

   return 0;

}

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

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

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

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

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

Ре­ше­ние.

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

2.  Та­ко­го числа не су­ще­ству­ет.

3.  В про­грам­ме до­пу­ще­на ти­пич­ная для на­чи­на­ю­щих про­грам­ми­стов ошиб­ка «сме­ще­ния кадра»: зна­че­ние пе­ре­мен­ной K, не­об­хо­ди­мое при пер­вом вы­пол­не­нии цикла, при­сва­и­ва­ет­ся до на­ча­ла цикла, а зна­че­ние для сле­ду­ю­ще­го обо­ро­та цикла вы­чис­ля­ет­ся в конце преды­ду­ще­го обо­ро­та. В ре­зуль­та­те при за­вер­ше­нии цикла K имеет зна­че­ние на 1 боль­ше, чем нужно. Вто­рая ошиб­ка  — не­вер­ное усло­вие цикла. В за­да­че тре­бу­ет­ся по­лу­чить сумму не боль­ше A, по­это­му при сумме, рав­ной A, вы­чис­ле­ния долж­ны быть пре­кра­ще­ны.

 

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

Пер­вая ошиб­ка: while s <= a do begin

Ис­прав­лен­ная стро­ка: while s < a do begin

Вто­рая ошиб­ка: writeln(k);

Ис­прав­лен­ная стро­ка: writeln(k-1);

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

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

место одна из сле­ду­ю­щих си­ту­а­ций.

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

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

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

2
Не вы­пол­не­ны усло­вия, поз­во­ля­ю­щие по­ста­вить 2 или 3 балла. При этом имеет место один из сле­ду­ю­щих слу­ча­ев.

1. Вы­пол­не­ны два пер­вых дей­ствия. При этом не­су­ще­ствен­но, на­сколь­ко пра­виль­но вы­пол­не­но тре­тье дей­ствие.

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

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

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