4.2.2
Graphs, Hash Tables & Stacks
Directed & Undirected Graphs
Directed & Undirected Graphs
Graphs are data structures used to represent data items which have connections between them, such as locations on a map or products on an e-commerce website.
data:image/s3,"s3://crabby-images/d01af/d01afe493f53546e9b19ff26e183f38762cfeb27" alt="Illustrative background for Graphs"
data:image/s3,"s3://crabby-images/d01af/d01afe493f53546e9b19ff26e183f38762cfeb27" alt="Illustrative background for Graphs ?? "content"
Graphs
Graphs
- Graphs consist of ‘nodes’ or ‘vertices’ which are joined by ‘arcs’ or ‘edges’ and can either be directed or undirected.
- A directed graph is one where the connections between the nodes only go in one direction (the arcs are represented as arrows).
- In an undirected graph, the connections are two-way.
data:image/s3,"s3://crabby-images/f0f03/f0f034339f45d3e81c81a3d9768d2a56634d3ee1" alt="Illustrative background for Graph traversal"
data:image/s3,"s3://crabby-images/f0f03/f0f034339f45d3e81c81a3d9768d2a56634d3ee1" alt="Illustrative background for Graph traversal ?? "content"
Graph traversal
Graph traversal
- There are two methods of traversing a graph:
- Depth-first.
- Breadth-first.
data:image/s3,"s3://crabby-images/8f127/8f1271b40c34ea428c5f8987e87c13de902a8e09" alt="Illustrative background for Depth-first traversal"
data:image/s3,"s3://crabby-images/8f127/8f1271b40c34ea428c5f8987e87c13de902a8e09" alt="Illustrative background for Depth-first traversal ?? "content"
Depth-first traversal
Depth-first traversal
- Depth-first traversal involves travelling down one route as far as possible, before reversing and travelling as far down the next route as possible.
- In the graph shown, depth-first traversal would involve visiting the nodes in the following order:
- A, B, E, C, D, G, F
data:image/s3,"s3://crabby-images/8f127/8f1271b40c34ea428c5f8987e87c13de902a8e09" alt="Illustrative background for Breadth-first"
data:image/s3,"s3://crabby-images/8f127/8f1271b40c34ea428c5f8987e87c13de902a8e09" alt="Illustrative background for Breadth-first ?? "content"
Breadth-first
Breadth-first
- Breadth-first traversal involves visiting all the adjoining nodes for each node in turn.
- In the graph shown, breadth-first traversal would involve visiting the nodes in the following order:
- A, B, C, E, D, F, G
Hash Tables
Hash Tables
A hash table is a data structure used for very large collections of data or where quick access to the data is required, such as customer records or password verification.
data:image/s3,"s3://crabby-images/f7199/f7199bb5cfd08aa5c4be0bd09e0538c7aa844a43" alt="Illustrative background for Hashing algorithm"
data:image/s3,"s3://crabby-images/f7199/f7199bb5cfd08aa5c4be0bd09e0538c7aa844a43" alt="Illustrative background for Hashing algorithm ?? "content"
Hashing algorithm
Hashing algorithm
- Hashing algorithms allows for the efficient location and retrieval of data.
- The hashing algorithm generates indexes based on the key fields of sets of data.
- A common example of a hashing algorithm is one which takes the key and divides it by the number of storage spaces available.
- The remainder is then used as the address at which to store the key.
data:image/s3,"s3://crabby-images/7a440/7a440bbe9c16121d7c504913048b42069bd345f7" alt="Illustrative background for Example"
data:image/s3,"s3://crabby-images/7a440/7a440bbe9c16121d7c504913048b42069bd345f7" alt="Illustrative background for Example ?? "content"
Example
Example
- If the keys 738, 271 and 560 need storing in a hash table with 6 storage spaces, the process would be as follows:
- Calculate the remainder when 738 is divided by 6.
- 738 MOD 6 = 0
- That means first key should be stored in location 0.
data:image/s3,"s3://crabby-images/15c65/15c65182a4af6a30610a8e3ae240583f603d1e9e" alt="Illustrative background for Example cont."
data:image/s3,"s3://crabby-images/15c65/15c65182a4af6a30610a8e3ae240583f603d1e9e" alt="Illustrative background for Example cont. ?? "content"
Example cont.
Example cont.
- For the second key, 271 MOD 6 = 1.
- We store this in location 1.
- For the third key, 560 MOD 6 = 2.
- We store this in location 2.
data:image/s3,"s3://crabby-images/4681c/4681cf5a8051f05970f1a9d897eb65b6d6a04923" alt="Illustrative background for Collisions"
data:image/s3,"s3://crabby-images/4681c/4681cf5a8051f05970f1a9d897eb65b6d6a04923" alt="Illustrative background for Collisions ?? "content"
Collisions
Collisions
- A perfect hashing algorithm will always generate a unique index.
- Should this not be the case, a ‘collision’ is said to occur .
- When a collision occurs, a rehashing algorithm is used to determine the next available slot in which to store the data.
- Alternatively, we can create a separate data structure such as a linked list from each storage location and store the collisions there.
data:image/s3,"s3://crabby-images/cbb75/cbb7573a80febd0e9247be5076484ea36119de37" alt="Illustrative background for Example"
data:image/s3,"s3://crabby-images/cbb75/cbb7573a80febd0e9247be5076484ea36119de37" alt="Illustrative background for Example ?? "content"
Example
Example
- Key 362 would need adding to the hash table above in location 2 as:
- 362 MOD 6 = 2
- However, it’s already filled by 560.
- In this case, the next available slot is location 3, so key 362 is stored there.
Stacks
Stacks
A stack is a data structure where data items are always added and removed from the top. It is often referred to as a ‘last in, first out’ data structure.
data:image/s3,"s3://crabby-images/33349/333494e8de372f30c2005fbcab86cec06955530d" alt="Illustrative background for Stacks"
data:image/s3,"s3://crabby-images/33349/333494e8de372f30c2005fbcab86cec06955530d" alt="Illustrative background for Stacks ?? "content"
Stacks
Stacks
- A stack is a data structure where data items are always added and removed from the top. It is often referred to as a ‘last in, first out’ data structure.
- Stacks can be implemented using other data structures, such as arrays or linked lists. In either case, an extra variable is required to identify the top of the stack.
data:image/s3,"s3://crabby-images/33052/3305285b3d3ec6865912010596516f778894e1d0" alt="Illustrative background for Stack operations"
data:image/s3,"s3://crabby-images/33052/3305285b3d3ec6865912010596516f778894e1d0" alt="Illustrative background for Stack operations ?? "content"
Stack operations
Stack operations
- Several operations can be carried out on stacks:
- push() - adds an item to the top of a stack.
- pop() - removes and displays the item at the top of a stack
- peek() - displays the item at the top of a stack without removing it
- isEmpty() - checks to see if the stack is empty
- isFull() - checks to see if the stack is full
data:image/s3,"s3://crabby-images/1d525/1d5258905989319768d6fc106ab4962f17215ac4" alt="Illustrative background for Uses"
data:image/s3,"s3://crabby-images/1d525/1d5258905989319768d6fc106ab4962f17215ac4" alt="Illustrative background for Uses ?? "content"
Uses
Uses
- The most common use of stacks is to reverse the order of a set of data items, as they are ‘popped’ in the opposite order that they were ‘pushed’ to a stack.
- They are also used by processors to handle interrupts.
- Stacks can be ‘static’ (fixed in size) or ‘dynamic’ (able to grow in size as necessary)
data:image/s3,"s3://crabby-images/29e91/29e9158c842a12e16a002353957c0dcee9883f4e" alt="Illustrative background for Errors"
data:image/s3,"s3://crabby-images/29e91/29e9158c842a12e16a002353957c0dcee9883f4e" alt="Illustrative background for Errors ?? "content"
Errors
Errors
- Stack overflow errors can occur in static stacks when attempting to push an item onto a stack that is full.
- Similarly, when trying to pop from an empty stack a stack underflow error occurs.
1Components of a Computer
1.1Structure & Function of the Processor
1.2Types of Processors
2Software & Software Development
2.1Systems Software
2.2Applications Generation
2.3Software Development
3Exchanging Data
3.1Compression, Encryption & Hashing
3.3Networks
4Data Types, Data Structures & Algorithms
4.1Data Types
5Legal, Moral, Cultural & Ethical Issues
5.1Computing Related Legislation
6Elements of Computational Thinking
6.1Thinking Abstractly
6.2Thinking Procedurally
6.3Thinking Logically
7Problem Solving & Programming
7.1Programming Techniques
7.2Programming Construction
Jump to other topics
1Components of a Computer
1.1Structure & Function of the Processor
1.2Types of Processors
2Software & Software Development
2.1Systems Software
2.2Applications Generation
2.3Software Development
3Exchanging Data
3.1Compression, Encryption & Hashing
3.3Networks
4Data Types, Data Structures & Algorithms
4.1Data Types
5Legal, Moral, Cultural & Ethical Issues
5.1Computing Related Legislation
6Elements of Computational Thinking
6.1Thinking Abstractly
6.2Thinking Procedurally
6.3Thinking Logically
7Problem Solving & Programming
7.1Programming Techniques
7.2Programming Construction
data:image/s3,"s3://crabby-images/9220a/9220a64e707af924249b072e9ddcfcd413526ea9" alt="Go student ad image"
Unlock your full potential with GoStudent tutoring
Affordable 1:1 tutoring from the comfort of your home
Tutors are matched to your specific learning needs
30+ school subjects covered