DISCLib is a Non-Object-Oriented Python library for teaching data structure and algorithms at Universidad de los Andes, developed by professors and staff in the Faculty of Engineering, Department of Systems and Computer Engineer #DISC.
View Demo and Examples · Report Bug · Request Feature
Table of Contents (up to date)
This project was created as a pedagogical library to teach the undergraduate students in the Systems and Computer Engineer program at Universidad de los Andes and others in the faculty to use and understand data structures and its related algorithm. This includes Arrays, Lists, Maps, Ordered Maps, Binary Search Trees (BST), Red Black Trees (RBT) and Graphs.
IMPORTANT This is a work in progress. The project is mainly focused as a teaching tool for undergraduate college students and is not intended to be used as a full-functional library.
The project has four main parts:
-
DISClib Root folder with the library implementation.
-
ADT Folder with the main Abstract Data Types (ADT) implemented in the library.
- List Script implementing the ADT Lists in the library, configurable by Array List, Single Linked List and Double Linked List structures.
- Queue Script implementing the ADT queue based in the ADT List.
- Stack Script implementing the ADT stack based in the ADT List.
- Map Script implementing the ADT Map using Hash Tables as data structures, configurable by collision handling method to Linear Probing and Separate Chaining.
- Ordered Map Script implementing the ADT Ordered Maps using binary trees as data structures, configurable to Binary Search Trees (BST) and Red Black Tree (RBT).
- MinPQ Script implementing the ADT Min Priority Queue using heap data structures.
- Indexed MinPQ Script implementing the ADT Indexed Min Priority Queue using the indexed heap data structure.
- Graph Script implementing the ADT Graph using adjacency lists as data structures.
-
Algorithms Folder with the main algorithms implemented to manage the ADTs.
- Graphs Folder with the algorithms to manage the ADT Graph.
- DFS Script implementing the Depth First Search (DFS) algorithm.
- BFS Script implementing the Breath First Search (BFS) algorithm.
- DFO Script implementing the Depth First Order (DFO) topological sorting algorithm.
- Cycles Script implementing the Cycle Detection algorithm.
- SCC Script implementing the Strongly Connected Components (SCC) algorithm.
- Prim Script implementing the Prim's algorithm.
- Dijkstra Script implementing the Dijkstra's algorithm.
- Bellman-Ford Script implementing the Bellman-Ford algorithm.
- Sorting Folder with the algorithms implementing sorting for the ADT List.
- Selection Sort Script implementing the Selection Sort algorithm.
- Insertion Sort Script implementing the Insertion Sort algorithm.
- Shell Sort Script implementing the Shell Sort algorithm.
- Merge Sort Script implementing the Merge Sort algorithm.
- Quick Sort Script implementing the Quick Sort algorithm.
- Trees Folder with the algorithms to manage the ADT Trees.
- Traversal Script implementing the Transversal algorithm for binary trees, it includes the preorder, inorder and postorder structure walkthrough.
- Graphs Folder with the algorithms to manage the ADT Graph.
-
Data Structures Folder with the main data structures implemented to support the ADTs in the library.
- Array List Script implementing the Array List data structure.
- Single Linked List Script implementing the Single Linked List data structure.
- Double Linked List Script implementing the Double Linked List data structure.
- Heap Script implementing the Heap data structure.
- Indexed Heap Script implementing the Indexed Heap data structure.
- Indexed MinPQ Node Script implementing the Indexed MinPQ Node data structure to support the Indexed Heap implementation.
- Separate Chaining Hash Table Script implementing the Separate Chaining Hash Table data structure.
- Linear Probing Hash Table Script implementing the Linear Probing Hash Table data structure.
- Map Entry Script implementing the Map Entry/Value data structure to support the Hash Table implementation.
- Binary Search Tree (BST) Script implementing the Binary Search Tree (BST) data structure for the ADT Ordered Map.
- BST Node Script implementing the BST Node data structure to support the Binary Search Tree (BST) data structure.
- Red Black Tree (RBT) Script implementing the Red Black Tree (RBT) data structure for the ADT Ordered Map.
- RBT Node Script implementing the RBT Node data structure to support the Red Black Tree (RBT) data structure.
- Adjacency List Script implementing the Adjacency List data structure for ADT Graph.
- Edge Script implementing the Edge data structure to support the Graph's Adjacency List implementation.
-
Utils Folder with the main utilities implemented to support the ADTs in the library.
- Error Handling Script implementing the Error Handling utility for all the libraries.
-
-
Test Folder with the tests for the library.
- List Scripts to evaluate the ADT Lists.
- Queue Scripts to evaluate the ADT Queue.
- Stack Scripts to evaluate the ADT Stack.
- Map Scripts to evaluate the ADT Map.
- Ordered Map Scripts to evaluate the ADT Ordered Map.
- Binary Search Tree Scripts to evaluate the ADT Binary Search Tree.
- MinPQ Scripts to evaluate the ADT Min Priority Queue.
- Graph Scripts to evaluate the ADT Graph.
NOTE: DISClib
uses the the config.py
scripts to configure the library's build path and allows the Python interpreter to find the relative path in any OS condition.
This library was built with the following technologies:
Mac OS
andWindows 10
for operating system.VS code
for the IDE.Python 3.6
for the programming language.Pytest
for the testing framework.
As a design principle DISClib minimize the use of Python external libraries in its implementation.
Finally, DISClib works between Python 3.6
and Python 3.9
versions.
This section contains the steps to get started with the library. As is the case with any other library, you need to install the library and then import it in your project.
As the library is not Object Oriented, you need to import the library in your project as a module using the following steps in Installation.
As a design principle DISClib minimize the use of Python external libraries in its implementation.
To execute the tests in the Test
folder, you need to install the Pytest
package.
pip install pytest
For the moment the DISClib is available as a local dependency in your project. To install it you can follow the next steps:
-
Create a new project folder.
-
Clone the repo with the command:
git clone https://github.com/ISIS1225DEVS/ISIS1225-Lib.git
-
Move the DISClib folder to the project folder.
-
Create a new Python file in the project folder.
-
Import the necessary DISClib ADT modules into your project with the command:
from DISClib.ADT import list as lt from DISClib.ADT import map as mp
-
Start coding!
DISCLib is a library that provides a set of ADT's to support the development and use of algorithms. Its intended as a teaching tool in the course ISIS1225-Estructuras de Datos y Algoritmos.
To check the laboratories repositories, go to the following links:
- ISIS1225-SampleMVC MVC pattern introduction laboratory.
- ISIS1225-SampleConflicts GitHub conflicts solution laboratory.
- ISIS1225-SampleList ADT List laboratory.
- ISIS1225-SampleSorts ADT List sorting algorithms laboratory.
- ISIS1225-sampleMap ADT Map laboratory.
- ISIS1225-SampleCollision ADT Map collision method laboratory.
- ISIS1225-SampleTree ADT Ordered Map (BST and RBT) laboratory.
- ISIS1225-sampleGraph ADT Graph laboratory.
- ISIS1225-SampleAlgorithm ADT Graph algorithms laboratory.
- ISIS1225-Reto1 First Challenge repository.
- ISIS1225-Reto2 Second Challenge repository.
- ISIS1225-Reto3 Third Challenge repository.
- ISIS1225-Reto4 Fourth Challenge repository.
For further information and contact, use the following links:
- Official Repository DISClib.
- Repository for Demo and Examples.
If you require further information, please contact us via this email
The Road so far led us to complete the following features:
- To include examples for all modules in the repository Demo and Examples.
- To clean some code and make it more readable.
- To standardize the functions and variables names throughout the library.
- To improve the library the documentation.
- To implement the Adjacency Matrix data structure for the ADT Graph.
See the open issues for a full list of proposed features (and known issues).
Contributions are what make the open-source community such an amazing place to learn, inspire, and create. Any contributions you make are greatly appreciated.
If you have a suggestion that would make this project better, please fork the repo and create a pull request. You can also simply open an issue with the tag "enhancement". Don't forget to give the project a star! Thanks again!
- Fork the Project.
- Create your Feature Branch (
git checkout -b feature/AmazingFeature
). - Commit your Changes (
git commit -m 'Add some AmazingFeature'
). - Push to the Branch (
git push origin feature/AmazingFeature
). - Open a Pull Request.
Copyright 2020, Departamento de sistemas y Computación, Universidad de Los Andes. Developed for the class "ISIS1225 - Estructuras de Datos y Algoritmos" or "ISIS1225 - Data Structure and Algorithms" in english.
This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more information go to GNU ORG.
- Dario Correal is the original author and main developer of the library.
- Santiago Arteaga is a contributor and repository administrator.
- Luis Florez is a contributor and developed examples and tutorials for the library.