By Rony Utevsky and Yehonatan Sofri.
A C++ project made for Advanced Programming 1 Project Mile stone 2, BIU, Fall 2019.
Link to GitHub
If compilation is required, go to project directory (where main.cpp is) and compile using
g++ -std=c++14 */*/*.cpp */*.cpp *.cpp -Wall -Wextra -Wshadow -Wnon-virtual-dtor -pedantic -o a.out -pthread
Program runs a server. The Server
accepts client on the given port (default is 5600). After client made a connection, program expects to get a matrix, a startin point and an end point followed by new lines. to end write end\n
.
- matrix - Matrix of numbers. should be of size NxN, each line represents a row. Numbers will be seperated by commas.
- Start point- coordinates of starting point - row and column.
- End point - coordinates of end point - row and column
1,2,3
4,5,6
7,8,9
0,0
2,2
end
will calculate the shortest path from 1 to 9. notice each line is ending with '\n'
.
after entering valid data, an A* algorithm will calculate shortest path from start to end and will write to client the steps and relative weight of steps. for example to the matrix in example input, solution will be:
Right (3), Right (6), Down (12), Down (21)
1
0,0
0,0
end
You're already there, honey!
data:image/s3,"s3://crabby-images/0ee50/0ee5005a1a0c990e20cbd746c0c26629e8ed0b88" alt="class diagram"
main thread will run a parallel server, allowing to handle multiple clients at the same time. each connection will create a new thread.
Contains a map of strings and booleans, each string is a file name that is stored in the cached_solutions
folder. boolean marks if the file is in the folder or not.
Pull requests are welcome. For major changes, please open an issue first to discuss what you would like to change.
Please make sure to update tests as appropriate.
Open source, free license (unless you're a BIU student...)