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

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

Ука­жи­те наи­боль­шее по­ло­жи­тель­ное пя­ти­знач­ное число x, при ко­то­ром после вы­пол­не­ния ал­го­рит­ма будет на­пе­ча­та­но сна­ча­ла 3, а потом 4.

 

Бей­сик Python

DIM X, Y, A, B AS INTEGER

A = 0

B = 0

INPUT X

WHILE X > 0

    Y = X MOD 10

    IF Y > 4 THEN A = A + 1

    IF Y < 7 THEN B = B + 1

    X = X \ 10

WEND

PRINT A

PRINT B

a = 0

b = 0

x = int(input())

while x > 0:

    y = x % 10

    if y > 4:

        a = a+1

    if y < 7:

        b = b+1

    x = x // 10

print(a)

print(b)

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

алг

нач

    цел x, y, a, b

    a := 0

    b := 0

    ввод x

    нц пока x > 0

        y := mod(x, 10)

        если y > 4

            то a := a + 1

        все

        если y < 7

            то b := b + 1

        все

        x := div(x, 10)

    кц

    вывод a, нс, b

кон

var x, y, a, b: integer;

begin

    a := 0;

    b := 0;

    readln(x);

    while x > 0 do

    begin

        y := x mod 10;

        if y > 4 then

            a := a + 1;

        if y < 7 then

            b := b + 1;

        x := x div 10

    end;

    writeln(a);

    writeln(b)

end.

Си++

#include <iostream>

using namespace std;

int main()

{

    int x, y, a, b;

    a = 0;

    b = 0;

    cin >> x;

    while (x > 0)

    {

        y = x % 10;

        if (y > 4)

            a = a + 1;

        if (y < 7)

            b = b + 1;

        x = x / 10;

    }

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

}

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

Ре­ше­ние.

а − ко­ли­че­ство цифр в числе, боль­ших, чем 4. b − ко­ли­че­ство цифр в числе, мень­ших, чем 7.

В нашем числе по­лу­ча­ет­ся одна цифра не мень­ше 7, две цифры не боль­ше, чем 4, и ещё две от 5 до 6.

Мак­си­маль­ное число, под­хо­дя­щее под все эти усло­вия  — 96644.

 

Ответ: 96644.

 

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

for i in range(100000, 1, -1):

x = i

a = 0

b = 0

while x > 0:

y = x % 10

if y > 4:

a = a + 1

if y < 7:

b = b + 1

x = x // 10

if a == 3 and b == 4:

print(i)

break


Аналоги к заданию № 8668: 9172 Все

Раздел кодификатора ФИПИ:
Гость 14.06.2015 23:24

Еще под­хо­дит число 99664. В таком слу­чае цифры 9,9,6,6 боль­ше че­ты­рех = 4 кол-ва.

А цифры 6,6,4 мень­ше семи = 3 кол-ва.

Никита Горохов

Долж­но быть три цифры, боль­ших четырёх, и че­ты­ре цифры, мень­ших семи, а не на­о­бо­рот.