Skip to content

Latest commit

 

History

History
88 lines (68 loc) · 3.67 KB

README.md

File metadata and controls

88 lines (68 loc) · 3.67 KB

"Connect Crab" Game

Background

There is a game featured in a video game titled "Lost in Play" found on Steam Marketplace.

The game is played on what seems like a traditional chess board but with size 6x6, and with crabs instead of tokens (befitting for the nautical theme at this point in the game). The object of the game is to move your color of crabs into a continuous row of 4 before your opponent is able to accomplish it for himself.

When playing this game, it is required to beat the seagull opponent in this mini-game, in order to proceed with the story of the real game. I found this rather difficult, so I decided to create this application to decide the best move given any situation.

The game is initialized as follows: image with you playing as the red crabs, and your opponent playing as blue.

│Θ1│  │Ψ1│Θ2│  │Ψ2│ 
│  │  │  │  │  │  │
│Ψ3│  │  │  │  │Θ3│
│Θ4│  │  │  │  │Ψ4│
│  │  │  │  │  │  │
│Ψ5│  │Θ5│Ψ6│  │Θ6│

You always play first in the game, so an example of possible moves involve any that move a red crab in a direction that allows at least one space of movement:

  • Ψ1 down (4 spaces)
  • Ψ1 left (1 space)
  • Ψ2 down (1 space)
  • Ψ2 left (1 space)
  • Ψ3 up (1 space)
  • Ψ3 right (4 spaces)
  • Ψ4 down (1 space)
  • Ψ4 left (4 spaces)
  • Ψ5 up (1 space)
  • Ψ5 right (1 space)
  • Ψ6 up (4 spaces)
  • Ψ6 right (1 space)

As you can see, each of the 6 crabs the user has in the initial board set up has 2 moves it can make for a total of 12 possible leading moves. (Many of which are isometrically identical accounting for the rotation of the board, but this isn't that important to the puzzle, it is just an observation.)

Of course, some of these moves, especially as the game progresses, are more advantageous than others as they get someone closer to victory.

Current Solver Implementation

The following is the strategy the existing solver will employ to determine its next move suggestion:

---
title: Solver Logic
---
flowchart TD
    0[/Game is in terminal state?/]
    0 -->|Yes| 0F[/<em>throw exception</em>\]
    0 -->|No| 0S[Retrieve all possible moves]
    0S --> 1[/Move exists that results in victory?/]
    1 -->|Yes| 1S[/Take it\]
    1 -->|No| 2[/Move exists that blocks an opponent's victory?/]
    2 -->|Yes| 1S
    2 -->|No| 3[Randomly choose an available move]
    3 --> 1S
Loading

How to use

To use the solver, build the jar, and run it on the command line.

mvn clean package
java -jar target/connect-crab-solver.jar
  • Performs the first move that the solver recommends
    • Perform the move that is told to you from the tool exactly, because this iteration of the tool does not account for mistakes. There is no correcting the board configuration in the event of a mis-input move into the game.
  • Then, input the move the opponent made to progress the state of the board and prompt the solver to calculate the next optimal move.
    • A move input requires identifying the piece number and the direction in which the piece should move separated by a space:
      > 4 L
      
  • Repeat until victory! (Or until failure, in which case there is work to do on the solver…)

Note on performance

It should be noted, I didn't work very hard on the artificial intelligence for this tool. However, it was powerful enough for me to win on my first try. Feel free to submit suggestions that would improve the performance of the solver.