This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
notes:data:fall2023:projects:waq0 [2023/11/09 00:22] – [Function to Enqueue and Explanation] wgates1 | notes:data:fall2023:projects:waq0 [2023/11/16 01:20] (current) – [Shuffling the Queue] cfoster8 | ||
---|---|---|---|
Line 46: | Line 46: | ||
card-> | card-> | ||
- | // If the queue is empty than both front and rear are set to card | + | // If the queue is empty then both front and rear are set to card |
if (q-> | if (q-> | ||
{ | { | ||
Line 62: | Line 62: | ||
} | } | ||
</ | </ | ||
+ | |||
+ | Do NOT forget to " | ||
There are a couple of things to note about this example. First off, it is based on the previous struct in the section "Queue Struct" | There are a couple of things to note about this example. First off, it is based on the previous struct in the section "Queue Struct" | ||
+ | This function would come in handy in a card game like War. In War, two players show their cards and whoever has a higher card wins that hand. So when making this game, enqueue would be used to add the other player' | ||
+ | |||
+ | ====Shuffling the Queue==== | ||
+ | |||
+ | You can't shuffle a queue from within the queue itself, you would need to pop every item off of it, shuffle that, and then push them all back. It's not too bad, but it may seem counter-intuitive. | ||
+ | |||
+ | You need a loop to pull everything out of the queue, and then a shuffle function in the middle to shuffle the list you made out of the queue, and finally another loop to push it all back into the queue. | ||
+ | |||
+ | Pseudo-code of it looks like so: | ||
+ | |||
+ | while(queue-is-not-empty){ | ||
+ | pop(queue); | ||
+ | } | ||
+ | shuffle_deck(); | ||
+ | while(deck-is-not-empty){ | ||
+ | push(queue); | ||
+ | } | ||
+ | ====real-world applications of queues==== | ||
+ | |||
+ | In real-world applications, | ||
+ | |||
+ | In networking, particularly in the realm of routers, queues are pivotal for managing and prioritizing data packets as they traverse the network. Routers employ queues to temporarily hold incoming packets before forwarding them to their destination. This helps ensure that packets are processed in the order they are received, preventing data congestion and maintaining the integrity of the transmitted information. Additionally, |