Indexing is inefficient, since every node has to be looked at.
Iteration in general involves a lot of jumping around on the heap, which takes more time and makes the operation hard to cache.
Reversing a list is very inefficient.
The last point is important, so, commonly, a linked-list implementation will have a link back as well, which makes it a doubly linked list.
Become an O’Reilly member and get unlimited access to this title plus top books and audiobooks from O’Reilly and nearly 200 top publishers, thousands of courses curated by job role, 150+ live events each month, and much more.