Python lists can be reversed using many python method such as using slicing method or using reversed() function. This article discusses how both of these work and Which one of them seems to be the faster one and Why.
Code: Reversing a list using Slicing.
Original list : [110, 220, 330, 440, 550] Reversed list elements : 550 440 330 220 110
Explanation : The format[a : b : c] in slicing states that from an inclusive to b exclusive, count in increments of c. In above code, a and b is blank and c is -1. So it iterates the entire list counting from the last element to the first element resulting in a reversed list.
Code: Reversing a list Using reversed() built-in function.
Original list : [110, 220, 330, 440, 550] Iterator object : <list_reverseiterator object at 0x7fbd84e0b630> Reversed list elements : 550 440 330 220 110
Explanation : The built-in reversed() function in Python returns an iterator object rather than an entire list.
For a comparatively large list, under time constraints, it seems that the reversed() function performs faster than the slicing method. This is because reversed() just returns an iterator that iterates the original list in reverse order, without copying anything whereas slicing creates an entirely new list, copying every element from the original list. For a list with 106 Values, the reversed() performs almost 20,000 better than the slicing method. If there is a need to store the reverse copy of data then slicing can be used but if one only wants to iterate the list in reverse manner, reversed() is definitely the better option.
Attention geek! Strengthen your foundations with the Python Programming Foundation Course and learn the basics.
To begin with, your interview preparations Enhance your Data Structures concepts with the Python DS Course.
- Python | Which is faster to initialize lists?
- Python reversed() function
- Python | Reversed Split Strings
- Python | Reversed Order keys in dictionary
- Python - K elements Reversed Slice
- Python - Assign Reversed Values in Dictionary
- Python | Making program run faster
- Why is Numpy faster in Python?
- R-CNN vs Fast R-CNN vs Faster R-CNN | ML
- Faster R-CNN | ML
- Python program to check if a string has at least one letter and one number
- Java vs Python - Which One Should I Learn?
- Count of pairs of strings which differ in exactly one position
- Program to cyclically rotate an array by one in Python | List Slicing
- Python | Check if two lists have at-least one element common
- Python | Program that matches a word containing 'g' followed by one or more e's using regex
- Python | Program to generate one-time password (OTP)
- Python | Check if one list is subset of other
- Python regex to find sequences of one upper case letter followed by lower case letters
- Python program to check if number is palindrome (one-liner)
If you like GeeksforGeeks and would like to contribute, you can also write an article using contribute.geeksforgeeks.org or mail your article to email@example.com. See your article appearing on the GeeksforGeeks main page and help other Geeks.
Please Improve this article if you find anything incorrect by clicking on the "Improve Article" button below.