I understand the definition of a Linked List, but how can it be represented and related to a common concept or item? For example, composition (EDIT: originally said 'inheritance') in OOP can be related to automobiles. All (most) automobiles in real life are the essentially same thing; an automobile has an Engine, you can start() it, you can make the car go(), stop() and so on. An automobile would typically have a maximum passenger capacity but it would differ between a Bus and a SportsCar, which are both automobiles. Is there some real life, intuitive example of the plain ole' singly Linked List like we have with inheritance? The typical textbook Linked List example shows a node with an integer and a pointer to the next, and it just doesn't seem very useful. Your input is appreciated.
33.7k 21 21 gold badges 116 116 silver badges 149 149 bronze badges asked Mar 13, 2009 at 19:09 JStims JStimsYou are confusing inheritance with composition. You said it yourself: an Automobile has_an Engine, not is_an Engine.
Commented Mar 13, 2009 at 19:13I am not confused. The engine would be declared in the Automobile class and inherited in the Bus or SportsCar class. Besides, this post is not about inheritance.
Commented Mar 13, 2009 at 19:17If you are not confused, your text is. You mention the textbook example of composition, not inheritance. You add an example of inheritance of attributes later. I understand what the question is about, though, and it's interesting. That's why I'm not downvoting it.
Commented Mar 13, 2009 at 20:10The example means that the Automobile interface has a getEngine() method and a start() method. This is an example of interface/inheritence.
Commented Mar 13, 2009 at 20:17Are you asking for an analogy, similar to the common (but flawed, I think) cars <->inheritance? Or a programming problem where you'd use a linked list?->
Commented Mar 13, 2009 at 20:35A linked list is like a conga line. Everyone holds the hips of the person in front of them and their hips are held in turn by the person to their rear, excepting only those in the front and the back. The only way to add people to the line is to find the right spot and decouple that connection, then insert the new person or people.
answered Mar 13, 2009 at 19:25 Brian Guthrie Brian Guthrie 2,848 2 2 gold badges 19 19 silver badges 13 13 bronze badgesI think their hands would be the pointer, and instead of pointing to the next person, they'd point to what we would consider the previous person, but that works really well. +1
Commented Mar 13, 2009 at 19:28I worry that that would encourage people to walk backwards, which is a bad scene if most of the conga participants are drunk (as is so often the case).
Commented Mar 14, 2009 at 3:28I'm assuming you want a more metaphorical explanation than the book definition, instead of examples of how you could use a linked list.
A linked list is kind of like a scavenger hunt. You have a clue, and that clue has a pointer to place to find the next clue. So you go to the next place and get another piece of data, and another pointer. To get something in the middle, or at the end, the only way to get to it is to follow this list from the beginning (or to cheat ;) )
answered Mar 13, 2009 at 19:27 Mike Cooper Mike Cooper 2,998 2 2 gold badges 26 26 silver badges 29 29 bronze badges +1 Neat metaphor. I'm curious how one would cheat, but I suspect this is just humor. Commented Mar 13, 2009 at 19:30Lutz: to cheat, you'd store an iterator from a previous operation, so you don't have to loop again the next time. :)
– Iraimbilanja Commented Mar 13, 2009 at 19:33What is a practical, real world example of the Linked List?
The simplest and most straightforward is a train.
Train cars are linked in a specific order so that they may be loaded, unloaded, transferred, dropped off, and picked up in the most efficient manner possible.
For instance, the Jiffy Mix plant needs sugar, flour, cornmeal, etc. Just around the bend might be a paper processing plant that needs chlorine, sulfuric acid, and hydrogen.
Now, we can stop the train, unload each car of its contents, then let the train go on, but then everything else on the train has to sit while flour is sucked out of the caisson, then the sugar, etc.
Instead, the cars are loaded on the train in order so that a whole chunk of it can be detached, and the remainder of the train moves on.
The end of the train is easier to detach than a portion in the middle, and vastly easier than detaching a few cars in one spot, and a few cars in another spot.
If needed, however, you can insert and remove items at any point in the train.
Much like a linked list.
answered Mar 13, 2009 at 19:37 Adam Davis Adam Davis 93.2k 60 60 gold badges 270 270 silver badges 333 333 bronze badgesFirst thing to understand is that a linked list is conceptually the same as an array.
The only difference is in the efficiency of various operations. Most importantly:
Thus any analogy that can be used for an array (all the engines of a plane, all the items on a shopping list. ) also applies to a linked list, but the efficiency consideration could make it appropriate to make another analogy:
An array would be boxes in a bookcase. When you remove the box from from the n-th row, all boxes from n+1 up need to be moved one shelf down (so you don't have a troublesome empty shelf).
A linked list, conversely, would be a necklace. When you find you don't like that blue jewel anymore, take it out of the sequence and tie the resulting two ends together. No need to loop through each pearl and displace it just so you can fix your necklace.
answered Mar 13, 2009 at 19:31 Iraimbilanja Iraimbilanja In the necklace example, what about deletion? Commented Sep 22, 2013 at 20:57Waiting line at a teller/cashier, etc.
A series of orders which must be executed in order.
Any FIFO structure can be implemented as a linked list.
answered Mar 13, 2009 at 19:11 69.1k 31 31 gold badges 173 173 silver badges 214 214 bronze badges+1: Each person is the head of a list, with a list behind them. Except the last person, who is the head of an empty list.
Commented Mar 13, 2009 at 19:14Hmm. What about the pointer? If I'm standing in line, I really don't care about the person behind me and the cashier is not going to ask me where the next person is. I'm trying to think of a real-world model here.
Commented Mar 13, 2009 at 19:19The pointer doesn't really matter. The important part of a linked list is that it's really easy to add an element to the end, or the beginning, or anywhere in the list. Try doing that with a conventional array. Imagine someone in the line decides to cut, or someone steps out to go to the bathroom.
Commented Mar 13, 2009 at 19:22The pointer is implicit in real life. Imaging a line so long you don't see the teller. The only way you know to advance is when the person in front of you walks up.
Commented Mar 13, 2009 at 19:22. Both situations are very difficult to model using a normal array, because they involve copying large chunks of the array to a different part. But with a linked list, they're very simple.
Commented Mar 13, 2009 at 19:22Real life example for:
**1) Singly linked list **
2) Doubly linked list
3) Circular linked list
I remember, many years ago, in one of my first college classes, wondering where I would ever , ever use a linked list. Today, I don't think there is a single project I work on where I haven't used one, and in many places. It's an incredibly fundamental data structure, and believe me, it's used heavily in the real world.
It may seem slightly useless to you now, but a few years from now, ask yourself the same question, you'll find yourself surprised that you ever wondered where it would be used.
Edit: I noticed in one of your comments you asked about why the pointer matters. Someone rightly answered that the pointer doesn't really matter to a user of a linked list. A user just wants a list that contains a, well, list of things. How that list "contains" that list of things doesn't really matter to the user. The pointer is part of that "how". Imagine a line, drawn on the floor, that leads to a teller. People need to be standing on that line to be able to get to the teller. That line is a (and I admit, this is a bit of a stretch) analogy for the pointer a linked list uses. The first person, at the teller, on the line, is the head of the list. The person directly behind them on the line is the next in the list. And finally, the last person in the line, on the line, is the tail of the list.
answered Mar 13, 2009 at 19:15 26.3k 32 32 gold badges 112 112 silver badges 157 157 bronze badgesof course, for those applications you could have easily used a queue, stack or even just a vector. The point of lists is the ability to easily insert into the middle of them.
Commented Mar 13, 2009 at 20:22Internally, when you don't have C++ and boost, queues and stacks (and maybe vectors) are specific cases of linked lists. It's nice to understand that, even if you never have to know this to use them.
Commented Mar 13, 2009 at 20:45 What aspects of those cases make a linked-list better suited than, say, an array? Commented Jul 7, 2014 at 19:24Plenty of reasons. In the case of images that need to be burned to a CD, consider a UI where you're choosing multiple images. As you select / deselect images, it would be rather silly to resize an array, or copy over an old array to a new array with the necessary size - a list is a cleaner abstraction.
Commented Jul 7, 2014 at 19:34The way Blame moves around a bunch of software engineers working on different modules in a project.
First, the GUI guy gets blamed for the product not working. He checks his code and sees it's not his fault: the API is screwing up. The API guy checks his code: not his fault, it's a problem with the logger module. Logger module guy now blames database guy, who blames installer guy, who blames.
answered Mar 12, 2010 at 9:14 7,033 12 12 gold badges 52 52 silver badges 77 77 bronze badges An example of a circular linked list Commented Mar 2, 2017 at 2:06Your DNA molecules are double-linked lists.
answered Mar 12, 2010 at 9:01 4,599 4 4 gold badges 36 36 silver badges 48 48 bronze badgesA chain:
Especially the roller chain:
Each element of the chain is connected to its successor and predecessor.
1 1 1 silver badge answered Mar 12, 2010 at 9:21 Daniel Rikowski Daniel Rikowski 72.3k 62 62 gold badges 254 254 silver badges 336 336 bronze badgesIf you think about it, a "Link" is simply a way of identifying a "Next", "Previous", "Child" or "Parent" relationship among data instances. So, among real world applications you'll find a broad variety of applications. Think of a simple List (e.g. Grocery List) for basic Linked Lists. But consider too the uses to which we can place Graphs (plotting distances between cities on a map, interactions among species in biology) or Trees (hierarchies in an organization or data in an index of a database for two very diverse examples).
answered Mar 13, 2009 at 19:13 Mark Brittingham Mark Brittingham 28.8k 12 12 gold badges 81 81 silver badges 111 111 bronze badgesHe's not saying they're similar, just that there's a textbook example of inheritance, and asking if there are similar easy-to-get examples of the use of a linked list
Commented Mar 13, 2009 at 19:15Good point! I removed the line about OOP as it wasn't really needed. I scanned the question pretty quickly and thought that there was some confusion.
Commented Mar 13, 2009 at 19:18+1 Agreed. The real world equivalent is any list that you may write on paper. The "linked" part is merely the internal code mechanisms that a program would use to navigate the list. For our example, that would be the paper.
Commented Mar 13, 2009 at 19:19 Hmmm. someone voted me down on this one. I'd love an explanation of why this answer isn't helpful. Commented Mar 13, 2009 at 19:29Well, the reason I voted down is because your Grocery List example doesn't explain why a linked list is superior to an array implementation.
– Iraimbilanja Commented Mar 13, 2009 at 20:31A linked list can be used to implement a queue. The canonical real life example would be a line for a cashier.
A linked list can also be used to implement a stack. The cononical real ife example would be one of those plate dispensers at a buffet restaurant where pull the top plate off the top of the stack.
answered Mar 13, 2009 at 19:17 556 2 2 silver badges 8 8 bronze badgesIn the general case, linked lists are one of the most devilishly useful things you will encounter.
Real world examples:
Generally the metaphor I like to use for almost all linked data structures though is a deck of cards. Just about anything you can do with linked lists, you can use a deck of cards to visualise. This is particularly handy to show yourself what is going on in some of the more esoteric sorting algorithms.
My personal favorite: Bogosort = play 52 card pickup until your deck is sorted. :-)
answered Mar 13, 2009 at 20:29 44.6k 10 10 gold badges 75 75 silver badges 138 138 bronze badgesHuman brain can be a good example of singly linked list. In the initial stages of learning something by heart, the natural process is to link one item to next. It's a subconscious act. Let's take an example of mugging up 8 lines of Wordsworth's Solitary Reaper:
Behold her, single in the field, Yon solitary Highland Lass! Reaping and singing by herself; Stop here, or gently pass! Alone she cuts and binds the grain, And sings a melancholy strain; O listen! for the Vale profound Is overflowing with the sound.
Our mind doesn't work well like an array that facilitates random access. If you ask the guy what's the last line, it will be harder for him to tell. He will have to go from line one to reach there. It's even harder if you ask him what's the fifth line.
At the same time if you give him a pointer, he will go forward. Ok start from Reaping and singing by herself; ?. It becomes easier now. It's even easier if you could give him two lines, Alone she cuts and binds the grain, And sings a melancholy strain; because he gets the flow better. Similarly, if you give him nothing at all, he will have to start from the start to get the lines. This is classic linked list.
There should be few anomalies in the analogy which might not fit well, but this somewhat explains how linked list works. Once you become somewhat proficient or know the poem inside-out, the linked list rolls (brain) into a hash table or array which facilitates O(1) lookup where you will be able to pick the lines from anywhere.