Open In App

Reverse string in Python (6 different ways)

Last Updated : 23 Sep, 2023
Improve
Improve
Like Article
Like
Save
Share
Report

Python string library doesn’t support the in-built “reverse()” as done by other python containers like list, hence knowing other methods to reverse string can prove to be useful. This article discusses several ways to achieve it in Python

Example:

Input:  Geeksforgeeks
Output: skeegrofskeeG

Reverse a string in Python using a loop

In this example, we call a function to reverse a string, which iterates to every element and intelligently joins each character in the beginning so as to obtain the reversed string. 

Time complexity: O(n) 
Auxiliary Space: O(1) 

Implementation:

Python3




def reverse(s):
    str = ""
    for i in s:
        str = i + str
    return str
 
s = "Geeksforgeeks"
 
print("The original string is : ", end="")
print(s)
 
print("The reversed string(using loops) is : ", end="")
print(reverse(s))


Output

The original string is : Geeksforgeeks
The reversed string(using loops) is : skeegrofskeeG

Reverse a string in Python using recursion

The string is passed as an argument to a recursive function to reverse the string. In the function, the base condition is that if the length of the string is equal to 0, the string is returned. If not equal to 0, the reverse function is recursively called to slice the part of the string except the first character and concatenate the first character to the end of the sliced string. ‘

Implementation:

Python3




def reverse(s):
    if len(s) == 0:
        return s
    else:
        return reverse(s[1:]) + s[0]
 
 
s = "Geeksforgeeks"
 
print("The original string is : ", end="")
print(s)
 
print("The reversed string(using recursion) is : ", end="")
print(reverse(s))


Output

The original string is : Geeksforgeeks
The reversed string(using recursion) is : skeegrofskeeG

Time complexity: O(n), for recursion to reverse 
Auxiliary Space: O(n), for recursion call stack

Reverse string in Python using stack

An empty stack is created. One by one character of the string is pushed to the stack. One by one all characters from the stack are popped and put back to a string. 

Time complexity: O(n) 
Auxiliary Space: O(n) 

Implementation:

Python3




# Function to create an empty stack. It
# initializes size of stack as 0
def createStack():
    stack = []
    return stack
 
# Function to determine the size of the stack
def size(stack):
    return len(stack)
 
# Stack is empty if the size is 0
def isEmpty(stack):
    if size(stack) == 0:
        return true
 
# Function to add an item to stack . It
# increases size by 1
def push(stack, item):
    stack.append(item)
 
# Function to remove an item from stack.
# It decreases size by 1
def pop(stack):
    if isEmpty(stack):
        return
    return stack.pop()
 
# A stack based function to reverse a string
def reverse(string):
    n = len(string)
 
    # Create a empty stack
    stack = createStack()
 
    # Push all characters of string to stack
    for i in range(0, n, 1):
        push(stack, string[i])
 
    # Making the string empty since all
    # characters are saved in stack
    string = ""
 
    # Pop all characters of string and put
    # them back to string
    for i in range(0, n, 1):
        string += pop(stack)
 
    return string
 
 
# Driver code
s = "Geeksforgeeks"
print("The original string is : ", end="")
print(s)
print("The reversed string(using stack) is : ", end="")
print(reverse(s))


Output

The original string is : Geeksforgeeks
The reversed string(using stack) is : skeegrofskeeG

Reverse string in Python using an extended slice

Extended slice offers to put a “step” field as [start, stop, step], and giving no field as start and stop indicates default to 0 and string length respectively, and “-1” denotes starting from the end and stop at the start, hence reversing a string. 

Time complexity: O(n) 
Auxiliary Space: O(1) 

Implementation:

Python3




# Function to reverse a string
def reverse(string):
    string = string[::-1]
    return string
 
s = "Geeksforgeeks"
 
print("The original string is : ", end="")
print(s)
 
print("The reversed string(using extended slice syntax) is : ", end="")
print(reverse(s))


Output

The original string is : Geeksforgeeks
The reversed string(using extended slice syntax) is : skeegrofskeeG

Reverse string in Python using reversed() method

The reversed() returns the reversed iterator of the given string and then its elements are joined empty string separated using join(). And reversed order string is formed. 

Time complexity: O(n) 
Auxiliary Space: O(n) 

Implementation:

Python3




# Python code to reverse a string
# using reversed()
 
# Function to reverse a string
def reverse(string):
    string = "".join(reversed(string))
    return string
 
s = "Geeksforgeeks"
 
print("The original string is : ", end="")
print(s)
 
print("The reversed string(using reversed) is : ", end="")
print(reverse(s))


Output

The original string is : Geeksforgeeks
The reversed string(using reversed) is : skeegrofskeeG

Reverse string in Python using list comprehension()

List comprehension creates the list of elements of a string in reverse order and then its elements are joined using join(). And reversed order string is formed.

Time complexity: O(n)
Auxiliary Space: O(1) 

Implementation:

Python3




# Function to reverse a string
def reverse(string):
    string = [string[i] for i in range(len(string)-1, -1, -1)]
    return "".join(string)
 
s = "Geeksforgeeks"
 
print("The original string  is : ", s)
 
print("The reversed string(using reversed) is : ", reverse(s))


Output

The original string  is :  Geeksforgeeks
The reversed string(using reversed) is :  skeegrofskeeG

Reverse string in Python using the function call

Function to reverse a string by converting string to list then reversed it and again convert it to string.

Time complexity: O(n)
Auxiliary Space: O(1) 

Implementation:

Python3




# Function to reverse a string
# by converting string to list
# then reversed it and again convert it to string
def reverse(string):
    string = list(string)
    string.reverse()
    return "".join(string)
 
s = "Geeksforgeeks"
 
print("The original string  is : ", s)
 
print("The reversed string(using reversed) is : ", reverse(s))
 
# This code is contributed by Susobhan AKhuli


Output

The original string  is :  Geeksforgeeks
The reversed string(using reversed) is :  skeegrofskeeG


Previous Article
Next Article

Similar Reads

Python | Ways to split a string in different ways
The most common problem we have encountered in Python is splitting a string by a delimiter, But in some cases we have to split in different ways to get the answer. In this article, we will get substrings obtained by splitting string in different ways. Examples: Input : Paras_Jain_Moengage_best Output : ['Paras', 'Paras_Jain', 'Paras_Jain_Moengage',
2 min read
Different ways of sorting Dictionary by Keys and Reverse sorting by keys
Prerequisite: Dictionaries in Python A dictionary is a collection which is unordered, changeable and indexed. In Python, dictionaries are written with curly brackets, and they have keys and values. We can access the values of the dictionary using keys. In this article, we will discuss 10 different ways of sorting the Python dictionary by keys and a
8 min read
Different ways of sorting Dictionary by Values and Reverse sorting by values
Prerequisite: Dictionaries in Python A dictionary is a collection which is unordered, changeable, and indexed. In Python, dictionaries are written with curly brackets, and they have keys and values. We can access the values of the dictionary using keys. In this article, 10 different ways of sorting the Python dictionary by values and also reverse s
15+ min read
How to apply different titles for each different subplots using Plotly in Python?
Prerequisites: Python Plotly In this article, we will explore how to apply different titles for each different subplot. One of the most deceptively-powerful features of data visualization is the ability for a viewer to quickly analyze a sufficient amount of information about data when pointing the cursor over the point label appears. It provides us
2 min read
Extending a list in Python (5 different ways)
In this article, we are going to learn different methods of extending a list in Python. The list is the widely used Python data structure and it can be extended by adding elements to the list. There are various methods to extend the list in Python which includes using an inbuilt function such as append(), chain() and extend() function and using the
3 min read
Python | Different ways to kill a Thread
In general, killing threads abruptly is considered a bad programming practice. Killing a thread abruptly might leave a critical resource that must be closed properly, open. But you might want to kill a thread once some specific time period has passed or some interrupt has been generated. There are the various methods by which you can kill a thread
8 min read
Different ways to Invert the Binary bits in Python
We know how binary value for numbers look like. For example, the binary value for 10 (Number Ten) is 1010 (binary value). Sometimes it is required to inverse the bits i.e., 0's to 1's ( zeros to ones) and 1's to 0's (ones to zeros). Here are there few ways by which we can inverse the bits in Python. 1) Using Loops: By iterating each and every bit w
3 min read
Different ways to convert a Python dictionary to a NumPy array
In this article, we will see Different ways to convert a python dictionary into a Numpy array using NumPy library. It’s sometimes required to convert a dictionary in Python into a NumPy array and Python provides an efficient method to perform this operation. Converting a dictionary to NumPy array results in an array holding the key-value pairs of t
3 min read
Different Ways of Using Inline if in Python
Python offers a concise and expressive way to handle conditional logic in your code by using inline if. Whether you need an essential conditional expression or want to nest multiple conditions, inline can make your code more readable and maintainable. Among these tools is the inline if statement, an invaluable asset for crafting short, yet intuitiv
3 min read
Print lists in Python (6 Different Ways)
Printing lists in Python goes beyond a simple display of values; it empowers programmers to gain insights into their code's behavior and verify data integrity. Join us on a journey of exploration as we uncover different strategies to print lists, complemented by practical use cases and best practices. Input: lst = [2,5,6,8,9]Output: 2 5 6 8 9Explan
4 min read
Article Tags :
Practice Tags :