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

Си­сте­ма ко­манд ис­пол­ни­те­ля РОБОТ, «жи­ву­ще­го» в пря­мо­уголь­ном ла­би­рин­те на клет­ча­той плос­ко­сти:

вверх вниз влево впра­во

При вы­пол­не­нии любой из этих ко­манд РОБОТ пе­ре­ме­ща­ет­ся на одну клет­ку со­от­вет­ствен­но (по от­но­ше­нию к на­блю­да­те­лю): вверх ↑, вниз ↓, влево ←, впра­во →.

Че­ты­ре ко­ман­ды про­ве­ря­ют ис­тин­ность усло­вия от­сут­ствия стены у каж­дой сто­ро­ны той клет­ки, где на­хо­дит­ся РОБОТ (также по от­но­ше­нию к на­блю­да­те­лю):

свер­ху
сво­бод­но
снизу
сво­бод­но
слева
сво­бод­но
спра­ва
сво­бод­но

Цикл

ПОКА < усло­вие >

по­сле­до­ва­тель­ность ко­манд

КОНЕЦ ПОКА

вы­пол­ня­ет­ся, пока усло­вие ис­тин­но.

В кон­струк­ции

ЕСЛИ < усло­вие >

ТО ко­ман­да1

ИНАЧЕ ко­ман­да2

КОНЕЦ ЕСЛИ

вы­пол­ня­ет­ся ко­ман­да1 (если усло­вие ис­тин­но) или ко­ман­да2 (если усло­вие ложно)

 

Если РОБОТ начнёт дви­же­ние в сто­ро­ну на­хо­дя­щей­ся рядом с ним стены, то он раз­ру­шит­ся и про­грам­ма прервётся.

Сколь­ко кле­ток ла­би­рин­та со­от­вет­ству­ют тре­бо­ва­нию, что, начав дви­же­ние в ней и вы­пол­нив пред­ло­жен­ную про­грам­му, РОБОТ уце­ле­ет и оста­но­вит­ся в за­кра­шен­ной клет­ке (клет­ка F6)?

 

НА­ЧА­ЛО

ПОКА<спра­ва сво­бод­но ИЛИ снизу сво­бод­но >

ПОКА < снизу сво­бод­но >

вниз

КОНЕЦ ПОКА

ПОКА < спра­ва сво­бод­но >

впра­во

КОНЕЦ ПОКА

КОНЕЦ ПОКА

КОНЕЦ

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

Ре­ше­ние.

В дан­ной про­грам­ме РОБОТ по­сту­па­ет сле­ду­ю­щим об­ра­зом: спер­ва РОБОТ про­ве­ря­ет сво­бод­на ли клет­ка спра­ва или снизу от него, если это так, то РОБОТ пе­ре­хо­дит к пер­во­му внут­рен­не­му циклу. В этом цикле пока у ниж­ней сто­ро­ны клет­ки в ко­то­рой на­хо­дит­ся РОБОТ нет стены он про­дол­жа­ет дви­гать­ся вниз. Как толь­ко это усло­вие пе­ре­ста­нет вы­пол­нять­ся он пе­ре­хо­дит ко вто­ро­му внут­рен­не­му циклу. Этот внут­рен­ний цикл ана­ло­ги­чен пер­во­му, толь­ко те­перь про­ве­ря­ет­ся от­сут­ствие стены у пра­вой сто­ро­ны клет­ки.

Про­ана­ли­зи­ро­вав эту про­грам­мы при­хо­дим к вы­во­ду, что РОБОТ будет дви­гать­ся впра­во или вниз, пока у него есть такая воз­мож­ность. РОБОТ при дан­ной про­грам­ме ни­ко­гда не разобьётся.

Про­ве­рив все клет­ки по вы­ве­ден­но­му нами пра­ви­лу дви­же­ния РО­БО­ТА вы­яс­ня­ем, что число кле­ток, удо­вле­тво­ря­ю­щих усло­вию за­да­чи, равно 19.

Раздел кодификатора ФИПИ: 1.6.2 Вы­чис­ли­мость. Эк­ви­ва­лент­ность ал­го­рит­ми­че­ских мо­де­лей
Гость 08.01.2014 14:03

Здрав­ствуй­те.

Ска­жи­те, по­жа­луй­ста, по­че­му клет­ки D1 и D2 не под­хо­дят?

Петр Мурзин

По­сколь­ку стар­то­вав из них, Робот за­кон­чит своё дви­же­ние в клет­ке F2.

Александр Дорофеев 21.02.2014 20:10

А разве клет­ка F6 под­хо­дит? по про­грам­ме да, но тогда же робот не нач­нет дви­же­ние.

Петр Мурзин

На­сколь­ко я понял, вас сму­ща­ет фор­му­ли­ров­ка. Фразу "начав дви­же­ние" сле­ду­ет по­ни­мать как "начав вы­пол­не­ние про­грам­мы".