We are a group of people passionate about data structures and algorithms. We eye for implementing all the data structures given here.
There are many pre-exisiting packages available in the open source world based on the above idea. However, they lack the implementation of complex data structures and this makes us different. If you have worked with C++ and Python then you know how hard it is to code bug free AVL trees :-).Well, after this project you will not have to worry about it. In fact, we will keep each data structure independent from each other for easy code reusability.
As we know Python is an interepreted language and hence is slow as compared to C++, the most popular language for sports programming. We still decided to use Python because the software development can happen at a much faster pace and it is much easier to test various software designs and APIs as coding them out takes no time. However, keeping the need of the users in mind, we will shift to C++ backend, which will happen quickly as we would be required to just translate the tested code rather than writing it from scratch, after a few releases with APIs available for all the languages.
Follow the steps given below,
- Fork, https://github.com/codezonediitj/pydatastructs/
- Execute,
git clone https://github.com/<your-github-username>/pydatastructs/
- Change your working directory to
../pydatastructs
. - Execute,
git remote add origin_user https://github.com/<your-github-username>/pydatastructs/
- Execute,
git checkout -b <your-new-branch-for-working>
. - Make changes to the code.
- Add your name and email to the AUTHORS, if you wish to.
- Execute,
git add .
. - Execute,
git commit -m "your-commit-message"
. - Execute,
git push origin_user <your-current-branch>
. - Make a PR.
That's it, 10 easy steps for your first contribution. For future contributions just follow steps 5 to 10. Make sure that before starting work, always checkout to master and pull the recent changes using the remote origin
and then start following steps 5 to 10.
See you soon with your first PR.
We recommend you to introduce yourself on our gitter channel. You can include the courses you have taken relevant to data strucutres and algorithms, some projects, prior experience, in your introduction. This will help us to allocate you issues of suitable difficulty.
Please follow the rules and guidelines given below,
- Follow the numpydoc docstring guide.
- If you are planning to contribute a new data structure then first raise an issue for discussing the API, rather than directly making a PR.
- For the first-time contributors we recommend not to take a complex data strucutre, rather start with
linear data structures
orabstract data types
. You can also pick issues labelled asgood_first_issues
.
Keep contributing!!