Skip to main content

Simple implementation of data structures for python

Project description

pyfds

Simple implementaion of data structures (DS) for python

Content

  • linked list
  • doubly linked list
  • sorted linked list
  • stack
  • queue
  • priority queue
  • utils // (package)

Content of utils

  • node // single pointer node
  • dnode // double pointer node
  • pair

how to import utils

from pyfds.utils import *
pair = Pair()
or
import pyfds.utils
pair = utils.Pair()

Classes

  • List // linked list
  • DList // doubly linked list
  • SList // sorted linked list
  • Stack // stack
  • Queue // queue
  • PQueue // priority queue

API

List

Properties

  • first(self) // TODO: return the data in the first node
  • last(self) // TODO: return the data in the last node

Methodes

  • insert(self, data, pos=0) // TODO: add node in the entered position (pos=0 => add in the begining)
  • append(self, data) // TODO: add node in the end
  • delete(self, data) // TODO: delete all nodes hav the entered data
  • remove(self, pos=0) // TODO: return and remove node in the entered position (pos=0 => remove first node, pos=-1 => remove last node)

DList

Properties

  • first // TODO: return the data in the first node
  • last // TODO: return the data in the last node

Methodes

  • add_begin(self, data) // TODO: add a node to the begin
  • add_fin(self, data) // TODO: add a node to the fin
  • delete(self, data) // TODO: delete all nodes hav the entered data
  • remove(self, pos=0) // TODO: return and remove node in the entered position (pos=0 => remove first node, pos=-1 => remove last node)

SList

Properties

  • first // TODO: return the data in the first node
  • last // TODO: return the data in the last node

Methodes

  • append(self, data) // TODO: add a node to the list in a sorted way
  • delete(self, data) // TODO: delete all nodes hav the entered data
  • remove(self, pos=0) // TODO: return and remove node in the entered position (pos=0 => remove first node, pos=-1 => remove last node)

Note

  • the (reverse, sort, exchange) are not supported in this DS because they brake the rule of the Sorted Linked List

Stack

Properties

  • top // TODO: return the data in the first node

Methodes

  • push(self, data) // TODO: add a node to the top
  • pop(self) // TODO: return and remove the node in the top

Queue

Properties

  • front // TODO: return the data in the first node
  • back // TODO: return the data in the last node

Methods

  • enqueue(self, data) // TODO: add a node to the end
  • dequeue(self) // TODO: return and remove the first element

PQueue

Properties

  • front // TODO: return the data in the first node
  • back // TODO: return the data in the last node

Methods

  • enqueue(self, data) // TODO: add a node to the queue in a sorted way
  • dequeue(self) // TODO: return and remove the first element

Methods for all DSs

  • str(self) // USE: print([DS_name]) // TODO: display the DS
  • len(self) // USE: len([DS_name]) // TODO: return the lenth of the DS
  • empty(self) // TODO: return True if the DS is empty
  • clear(self) // TODO: clear the DS
  • find(self, data) // TODO: return the number of how many the entered data found in the DS
  • reverse(self) // TODO: return the reverse of the DS
  • sort(self) // TODO: sort the DS if its not sorted
  • exchange(self, n) // TODO: circular permutation for n time

classmethods for all DSs

// USE: [DS] = [DS_type].method([DS1], [DS2])
// Examples:
>>> stck3 = Stack.merge(stck1, stck2)
>>> Stack.swap([DS1], [DS2])
the tow DS parameters must be from the same DS

  • merge(cls, DS1, DS2) // TODO: return the merge of two DS in new DS
  • swap(cls, DS1, DS2) // TODO: swap between DS1 and DS2 (DS1 will be DS2 and DS2 will be DS1)

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

py-fds-3.1.1.tar.gz (5.7 kB view details)

Uploaded Source

Built Distribution

py_fds-3.1.1-py3-none-any.whl (21.6 kB view details)

Uploaded Python 3

File details

Details for the file py-fds-3.1.1.tar.gz.

File metadata

  • Download URL: py-fds-3.1.1.tar.gz
  • Upload date:
  • Size: 5.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/49.1.0 requests-toolbelt/0.9.1 tqdm/4.46.1 CPython/3.8.3

File hashes

Hashes for py-fds-3.1.1.tar.gz
Algorithm Hash digest
SHA256 9091651e6fc33f026a3d4b27ed6f1a3df0bf4257eef7bdecee97ae9feb8fc195
MD5 520ba9c9733520600e03c5b14ec178a6
BLAKE2b-256 b639c58fd30071b75b5a85e087ae2f05fe1419f17572bbbe4a46379ea3107dd4

See more details on using hashes here.

File details

Details for the file py_fds-3.1.1-py3-none-any.whl.

File metadata

  • Download URL: py_fds-3.1.1-py3-none-any.whl
  • Upload date:
  • Size: 21.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/49.1.0 requests-toolbelt/0.9.1 tqdm/4.46.1 CPython/3.8.3

File hashes

Hashes for py_fds-3.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 31425fcbdd0a71002eb25506cbc401f65f2e5d2e4132c8149f2aa54ef99f8b74
MD5 3ebbb4656dcb7a7d99061bee2a2e56a6
BLAKE2b-256 ee6cf710d260b064f01971467dc5574c50240c3f54b977e87e83390adc216fc3

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page