Skip to main content

How to Reverse a String in C without using C Reverse String function and using either Pointers or Recursive Function.

C Program to Reverse a String without using C Reverse String function (strrev() in string.h) and using either Pointers or Recursive Function is given below:-
1) C Example program to Reverse a String using pointers :

#include<stdio.h>
int strLength(char*); // user defined function declaration or function prototype
void strReverse(char*); // UDF declr or fun proto
main()
{
char str[100];
printf("Enter a String to be Reversed :");
gets(str); // using gets() instead of scanf() because scanf() does not take space char
strReverse(str); // function with argument as string variable str calls here
printf("Reverse of given String is \"%s\".\n", str);
return 0;
}
void strReverse(char *str) // strReverse() function defines here
{
int length, c;
char *begin, *end, temp;
length = strLength(str); // function strLength() calls here and which returns integer value to be stored in "length" variable.
begin = str;
end = str;
for ( c = 0 ; c < ( length - 1 ) ; c++ )
end++;
for ( c = 0 ; c < length/2 ; c++ )
{
temp = *end;
*end = *begin;
*begin = temp;
begin++;
end--;
}
}
int strLength(char *pointer) // strLength() function defines here, which returns an integer
{
int c = 0;
while( *(pointer+c) != '\0' )
c++;
return c;
}

2) C Example program to Reverse a String using Recursive Function ( function calls itself ) :

#include<stdio.h>
#include<string.h>
void strReverse(char*,int,int);
main()
{
char str[100];
printf("Enter a String to be Reversed :");
gets(str);
strReverse(str, 0, strlen(str)-1);
printf("Reverse of given String is \"%s\".\n", str);
return 0;
}
void strReverse(char *ch, int begin, int end)
{
char a, b, c;
if ( begin >= end )
return;
c = *(ch+begin);
*(ch+begin) = *(ch+end);
*(ch+end) = c;
strReverse(ch, ++begin, --end);
}

Popular posts from this blog

Swapping of Two Numbers in C or C Program to Swap Two Numbers

Swapping of Two Numbers in C or C Program to Swap Two Numbers or C program to Swap two numbers without using a third variable #include <stdio.h> #include <conio.h>  void main() {    int x, y, temp;    clrscr();    // to clear screen       printf("Enter the value of x and y\n");    scanf("%d%d", &x, &y);    printf("Before Swapping\nx = %d\ny = %d\n",x,y);    temp = x;    x    = y;    y    = temp;    /*       without using temp variable, this can be used    let x=4 and y=5    x = x + y ;   x=x+y => x=4+5 => x=9     y = x - y ;   y=x-y => y=9-5 => y=4  value changed    x = x - y ;   x=x-y => x=9-4 => x=5  value changed      */       printf("After Swapping\nx ...

C Model Question Papers for BCA 1st year Kannur Bharathiar MG Madras Bangalore University

C Model Question Papers for BCA 1st year Kannur Bharathiar MG Madras Bangalore University : Fist Year BCA Model Question Paper for C Programming Language :- Model Question Paper B.C.A. : I Year: Programming using C: Time: 3 Hrs. Max. Marks: 100 SECTION – A 1) Answer the following Questions : 10 x 2 = 20 M a) Define Algorithm. b) Define Identifier. c) What is the Purpose of sizeof() operator. d) Compare while and do-while loops. Justify your answer. e) Define Recursion. f) How can we initialize an array. g) What is the difference between structure and union ? h) Define Pointer variable. i) Define Macro. j) What is the purpose of rewind() function. Section – B Answer the following questions. 4 x 20 = 80 M 2. a) Explain the structure of C program. b) Explain features of C language. (or) c) Describe in brief the operators in C language. d) Write a C program to evaluate the following expression. (a+(b*c)/d) 3. a) Explain control structures with examples. (or) b) Explain different parameter ...

Find the Greatest Time in C or CPP from two different times.

Find the Greatest Time in C or CPP from two different times. Example Code: #include<iostream.h> #include<conio.h> class time { private: int hh,mm,ss; public: void get() { cout<<"\n enter hh,mm,ss:"; cin>>hh>>mm>>ss; } void show() { cout<<"\n hour:"<<hh<<"\n minute:"<<mm<<"\n second:"<<ss; } time greatest(time x) { if (hh>x.ss) return *this; else if(hh>x.hh) return x; else if(mm>x.mm) return *this; else if(mm<x.mm) return x; else if(ss>x.ss) return *this; else return x; } }; void main() { clrscr(); time t1,t2,t3; cout<<"\n enter time1:"; t1.get(); cout<<"\n enter time2:"; t2.get(); t3=t1.greatest(t2); cout<<"\n greatest time:"; t3.show(); getch(); }