Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/sondosaabed/optimal-coins-game-strategy
a java project that uses dynamic programming to implemnt the Optimal coins collecting game strategy
https://github.com/sondosaabed/optimal-coins-game-strategy
dynamic-programming java javafx optimal-game-strategy
Last synced: 8 days ago
JSON representation
a java project that uses dynamic programming to implemnt the Optimal coins collecting game strategy
- Host: GitHub
- URL: https://github.com/sondosaabed/optimal-coins-game-strategy
- Owner: sondosaabed
- License: mit
- Created: 2023-01-14T19:25:16.000Z (almost 2 years ago)
- Default Branch: main
- Last Pushed: 2023-05-05T15:40:07.000Z (over 1 year ago)
- Last Synced: 2024-11-06T15:40:51.019Z (about 2 months ago)
- Topics: dynamic-programming, java, javafx, optimal-game-strategy
- Language: Java
- Homepage:
- Size: 215 KB
- Stars: 10
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Optimal coins game strategy:
This project was created as part of Algorithm analysis course. A java project that uses dynamic programming to implemnt the Optimal game strategy of coins.# Problem Description
This is a two-player game. There are even number of coins arranged in a row. There will be alternate turns. In each turn, a player can either select the first coin in the row or the last coin in the row and keep it with him. The objective of the problem is to determine the maximum possible amount of money a player can definitely win, if he moves first.
In this problem, we will try to collect maximum amount without underestimating the opponent. We can choose either the first or the last coin in the row. We will pick the one which results in giving us lesser amount to ensure that we can definitely win this much of amount irrespective of opponent’s moves.
# Input and Output
Coins [] = 4, 15, 7, 3, 8, 9
Expected result= 27
The input.txt file is an example of the input file.
# App screenshots:
Main:
![1](https://user-images.githubusercontent.com/65151701/212492627-dfd90a0d-71f1-4f41-8454-dd2ddd9432fa.jpg)Browse file or input using the textbox:
![2](https://user-images.githubusercontent.com/65151701/212492630-30bac139-03ed-4653-98bc-a3fceb4e2005.jpg)The main after running the program:
![3](https://user-images.githubusercontent.com/65151701/212492637-e844f11c-4724-4881-bd44-40750540728d.jpg)The dynamic table filled using bottom up approach:
![4](https://user-images.githubusercontent.com/65151701/212492640-87c5f265-599b-4682-9e83-25f875a41a4b.jpg)A simualtion of the game in which player 1 gets the optimal solution:
![5](https://user-images.githubusercontent.com/65151701/212492644-19438a1f-5bab-4dcd-ada4-e51ce8511858.jpg)