This is my solution of Hackerrank BotClean Partially Observable with this info:
Solved score: 28.00pts
Difficulty: Hard
Score Obtained: 28.24pts
See Leaderboard
Let us consider a cleaning agent where the environment is partially observable
. The bot has the same actuators and sensors. But the sensors visibility is confined to its 8 adjacent
cells.
The first line contains two space separated integers which indicate the current position of the bot. The board is indexed using Matrix Convention
5 lines follow, representing the grid. Each cell in the grid is represented by any of the following 4 characters:
b
(ascii value 98) indicates the bot’s current position,d
(ascii value 100) indicates a dirty cell,-
(ascii value 45) indicates a clean cell in the grid, ando
(ascii value 111) indicates the cell that is currently not visible.
Output is the action that is taken by the bot in the current step. It can either be any of the movements in 4 directions or the action of cleaning the cell in which it is currently located. Hence the output formats are LEFT
, RIGHT
, UP
, DOWN
or CLEAN
.
Sample Input
0 0
b-ooo
-dooo
ooooo
ooooo
ooooo
Sample Output
RIGHT
Complete the function next_move that takes in 3 parameters: posr and posc denote the co-ordinates of the bot’s current position, and board denotes the board state, and print the bot’s next move.
The goal is to clean all the dirty cells in as few moves as possible. Your score is (200 - #bot moves)/25. All bots in this challenge will be given the same input. CLEAN is also considered a move.
Education Links