Program to Reverse a String using Pointers

Given a string, the task is to reverse this String using pointers.


Input: Geeks
Output: skeeG

Input: GeeksForGeeks
Output: skeeGroFskeeG

Approach: This method involves taking two pointers, one that points at the start of the string and the other at the end of the string. The characters are then reversed one by one with the help of these two pointers.






#include <stdio.h>
#include <string.h>
// Function to reverse the string
// using pointers
void reverseString(char* str)
    int l, i;
    char *begin_ptr, *end_ptr, ch;
    // Get the length of the string
    l = strlen(str);
    // Set the begin_ptr and end_ptr
    // initially to start of string
    begin_ptr = str;
    end_ptr = str;
    // Move the end_ptr to the last character
    for (i = 0; i < l - 1; i++)
    // Swap the char from start and end
    // index using begin_ptr and end_ptr
    for (i = 0; i < l / 2; i++) {
        // swap character
        ch = *end_ptr;
        *end_ptr = *begin_ptr;
        *begin_ptr = ch;
        // update pointers positions
// Driver code
int main()
    // Get the string
    char str[100] = "GeeksForGeeks";
    printf("Enter a string: %s\n", str);
    // Reverse the string
    // Print the result
    printf("Reverse of the string: %s\n", str);
    return 0;

Enter a string: GeeksForGeeks
Reverse of the string: skeeGroFskeeG

Attention reader! Don’t stop learning now. Get hold of all the important DSA concepts with the DSA Self Paced Course at a student-friendly price and become industry ready.

Check out this Author's contributed articles.

If you like GeeksforGeeks and would like to contribute, you can also write an article using or mail your article to 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.

Article Tags :
Practice Tags :