
- LISP Tutorial
- LISP - Home
- LISP - Overview
- LISP - Environment
- LISP - REPL
- LISP - Program Structure
- LISP - Basic Syntax
- LISP - Data Types
- Lisp Macros
- LISP - Macros
- LISP - Backquote and Comma
- LISP - Code Generation Using Macro
- LISP - Variable Capture and Hygienic macro
- LISP - Scope and Binding
- LISP - Macro Writing Style
- LISP - Macro Characters
- LISP - Read-Time Macros
- LISP - Compiler Macros
- LISP - Uses of Macros
- Lisp Functions
- LISP - Functions
- LISP - Functions vs Macros
- LISP - Calling Function using funcall
- LISP - Calling Function using apply
- LISP - Closures
- LISP - Functions as Arguments
- LISP - Functions as Return Values
- LISP - Recursion
- LISP - Built-in Functions
- Lisp Predicates
- LISP - Predicates
- LISP - Generic Data Type Predicates
- LISP - Specific Data Type Predicates
- LISP - Equality Predicates
- LISP - Numeric Predicates
- LISP - Comparison Predicates
- LISP - Logical Predicates
- LISP - List Predicates
- LISP - Custom Predicates
- LISP - Chaining Predicates
- Lisp Arrays
- LISP - Arrays
- LISP - Adjustable Arrays
- LISP - Fill Pointers in Arrays
- LISP - Specialized Arrays
- LISP - Arrays Properties
- LISP - Iterating over Arrays
- LISP - Multidimensional Arrays
- LISP - Row-Major Order
- Lisp Strings
- LISP - Strings
- LISP - String Concatenation
- LISP - String Comparison
- LISP - String Case Conversion
- LISP - String Trimmimg
- LISP - String Searching
- LISP - Getting Substring
- LISP - String Replacement
- LISP - Sorting Strings
- LISP - Merging Strings
- LISP - Accessing Characters of String
- LISP - String length
- LISP - Escape Sequences
- Lisp Sequences
- LISP - Sequences
- LISP - Accessing Element of Sequence
- LISP - Sequence length
- LISP - Getting Subsequence
- LISP - Search Element in Sequence
- LISP - Sequence Concatenation
- LISP - Reversing a Sequence
- LISP - Mapping Sequence Element
- LISP - position of Element
- LISP - Remove an Element
- LISP - Sort Sequence
- LISP - Merge Sequences
- LISP - every function
- LISP - some function
- LISP - notany function
- LISP - notevery function
- Lisp Lists
- LISP - Lists
- LISP - Accessing Elements of Lists
- LISP - Modifications to Lists
- LISP - Using mapcar on List
- LISP - Using mapc on List
- LISP - Using reduce on List
- LISP - Removing elements from List
- LISP - Reversing a List
- LISP - Sorting a List
- LISP - Searching a List
- LISP - List vs Vectors
- LISP - Matrix Multiplication
- Lisp Vectors
- LISP - Vectors
- LISP - Creating Vectors
- LISP - Accessing Elements of Vectors
- LISP - Modifications to Vectors
- LISP - Adjustable Vectors
- LISP - Specialized Vectors
- LISP - Vector Functions
- Lisp Set
- LISP - Set
- LISP - Adding elements to the Set
- LISP - Getting SubSet from a Set
- LISP - Set Difference
- LISP - Set Exclusive OR
- LISP - Set Intersection
- LISP - Set Union
- LISP - Representing Set with HashTable
- LISP - List as Set vs HashTable as Set
- Lisp Tree
- LISP - Tree
- LISP - Recursive Traversal
- LISP - Inorder Traversal
- LISP - Preorder Traversal
- LISP - Postorder Traversal
- LISP - Depth First Traversal
- LISP - Modifying Tree
- LISP - Search Tree
- LISP - Binary Tree
- Lisp Hash Table
- LISP - Hash Table
- Adding Values to Hash Table
- Removing Values from Hash Table
- Updating Values of Hash Table
- Iterating Hash Table Entries
- Searching key in HashTable
- Checking Size of HashTable
- Using Custom Equality Check
- Lisp - Input − Output
- LISP - Input − Output
- LISP - Streams
- LISP - Reading Data from Streams
- LISP - Writing Data to Streams
- LISP - File I/O
- LISP - String I/O
- LISP - Formatting with Format
- LISP - Interactive I/O
- LISP - Error Handling
- LISP - Binary I/O
- Lisp - Structures
- LISP - Structures
- LISP - Accessors and Mutators
- LISP - Structure Options
- LISP - Structure Types
- LISP - Applications and Best Practices
- Lisp - CLOS
- LISP - CLOS
- Lisp - Objects
- LISP - Class
- LISP - Slots and Accessors
- LISP - Generic Functions
- LISP - Class Precedence
- LISP - Metaobject Protocol
- LISP - Multimethods
- LISP - Multiple Inheritance
- LISP - Method Combinations
- LISP - Method Combinations
- LISP - :before Method Combination
- LISP - :primary Method Combination
- LISP - :after Method Combination
- LISP - :around Method Combination
- LISP - + Method Combination
- LISP - and Method Combination
- LISP - append Method Combination
- LISP Useful Resources
- Lisp - Quick Guide
- Lisp - Useful Resources
- Lisp - Discussion
Lisp - Representing Set with HashTable
In this chapter, we're discussing how to represent a Set with Hashtable.
Create a Set as HashTable
We're creating a set using a hashtable. A hashtable is a suitable datastructure to represent as Set as it has an average time complexity of O(1) to add, remove and contains operations.
; create a set using hashtable (defun make-set () (make-hash-table))
Add operation
This function will add an element to the set.
; define an add operation on set (defun set-add (set item) ; add item to the set (setf (gethash item set) t))
gethash item set − retrieves the hash value associated with the element in the set as hashtable.
setf − sets the value associated with element in the set as true. As key is present in the hashtable, it signifies that element is present in the set. If element is not present, gethash return non-nil value and setf will override the same.
Remove operation
This function will remove an element from the set.
; define remove operation on set (defun set-remove (set item) (remhash item set))
remhash item set − removes the item entry from the set as hashtable. If item is not present, remhash does nothing and returns nil.
Contains operation
This function checks an element existence in the set.
; define contains operation on set (defun set-contains-p (set item) (nth-value 1 (gethash item set)))
gethash item set − retrieves the hash value associated with the element in the set as hashtable and a boolean value as value is present or not.
nth-value 1 − retrieves the second return value, the boolean result to verify if element is present or not.
Get size operation
This function gets the size of hashtable as size of the set.
(defun set-size (set) (hash-table-count set))
Set to List operation
This function gets a list from a set for printing purpose. We're looping over hash keys and collecting them in a list.
; get set elements as a list (defun set-to-list (set) (loop for key being the hash-keys of set collect key))
List to Set operation
This function gets a Set from a List. We're looping over list values and adding them to the set.
; convert a list to set (defun list-to-set (list) (let ((set (make-set))) (dolist (element list set) (set-add set element))))
Example - Using hashtable as Set
Following example showcases the usage of hashtable as Set.
; create a set using hashtable (defun make-set () (make-hash-table)) ; define an add operation on set (defun set-add (set item) ; add item to the set (setf (gethash item set) t)) ; define remove operation on set (defun set-remove (set item) (remhash item set)) ; define contains operation on set (defun set-contains-p (set item) (nth-value 1 (gethash item set))) ; get size of the set as hashtable size (defun set-size (set) (hash-table-count set)) ; get set elements as a list (defun set-to-list (set) (loop for key being the hash-keys of set collect key)) ; convert a list to set (defun list-to-set (list) (let ((set (make-set))) (dolist (element list set) (set-add set element)))) ; Example Usage: (setf my-set (make-set)) ; add elements to the set (set-add my-set 10) (set-add my-set 20) ; adding duplicate have no effect (set-add my-set 10) ; print the set (format t "My Set: ~a~%" (set-to-list my-set)) ; print the size of the set (format t "Size of My Set: ~a~%" (set-size my-set)) ; check if elements are present in the set (format t "Contains 20? ~a~%" (set-contains-p my-set 20)) (format t "Contains 30? ~a~%" (set-contains-p my-set 30)) ; remove an element (set-remove my-set 10) (format t "My Set after removing 10: ~a~%" (set-to-list my-set))
Output
When you execute the code, it returns the following result −
My Set: (20 10) Size of My Set: 2 Contains 20? T Contains 30? NIL My Set after removing 10: (20)