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

Ниже на пяти язы­ках про­грам­ми­ро­ва­ния за­пи­сан ал­го­ритм. По­лу­чив на вход число x, этот ал­го­ритм пе­ча­та­ет два числа: a и b. Ука­жи­те наи­боль­шее из таких чисел x, при вводе ко­то­рых ал­го­ритм пе­ча­та­ет сна­ча­ла 3, а потом 14.

 

Бей­сикPython

DIM X, A, B AS INTEGER

INPUT X

A = 0: B = 0

WHILE X > 0

  A = A + 1

  IF X MOD 2 = 0 THEN

    B = B + X MOD 10

  END IF

  X = X \ 10

WEND

PRINT A

PRINT B

x = int(input())

a=0; b=0

while x>0:

  a = a+1

  if x%2==0:

    b += x%10

  x = x//10

print(a, b)

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

var x, a, b: integer;

begin

  readln(x);

  a := 0; b := 0;

  while x > 0 do

  begin

    a := a + 1;

    if x mod 2= 0 then

      b := b + x mod 10;

    x := x div 10;

  end;

  writeln(a); write(b);

end.

алг

нач

  цел x, a, b

  ввод x

  a := 0; b := 0

  нц пока x > 0

    a := a+1

    если mod(x,2)=0

      то b := b + mod(x,10)

    все

    x := div(x,10)

  кц

  вывод a, нс, b

кон

Си++

#include <iostream>

using namespace std;

int main()

{

  int x, a, b;

  cin >> x;

  a = 0; b = 0;

  while (x > 0) {

    a = a+1;

    if (x%2 == 0) {

      b = b + x%10;

    }

    x = x / 10;

  }

  cout << a << endl << b << endl;

  return 0;

}

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

Ре­ше­ние.

Дан­ный ал­го­ритм, по­лу­чая на вход число x, счи­та­ет ко­ли­че­ство цифр и скла­ды­ва­ет из них чет­ные.

 

Эта часть про­грам­мы сум­ми­ру­ет чет­ные числа, идя с конца:

if x mod 2= 0 then

b := b + x mod 10;

 

А эта  — пока число не ста­нет рав­ным нулю, скла­ды­ва­ет ко­ли­че­ство раз про­хож­де­ний через ал­го­ритм, а также уби­ра­ет по­след­нюю цифру числа:

while x > 0 do

begin

  a := a + 1;

  ...

  x := x div 10;

end;

 

Таким об­ра­зом, в числе три цифры. Сумма чет­ных цифр 14. Так как не­об­хо­ди­мо наи­боль­шее число, берем на пер­вое место 9, оно не­чет­ное (сум­ми­ро­вать­ся не будет). На вто­рое и тре­тье место 8 + 6. Наи­боль­шее из этих чисел ста­вим во вто­рой раз­ряд. В итоге по­лу­ча­ем число 986.

 

Ответ: 986.

 

При­ведём дру­гое ре­ше­ние на языке Python.

for i in range(10000, 0, -1):

x = i

a = 0

b = 0

while x > 0:

a = a + 1

if x % 2 == 0:

b += x % 10

x = x // 10

if a == 3 and b == 14:

print(i)

break

Раздел кодификатора ФИПИ: