C Programming - Strings - Discussion

Discussion Forum : Strings - Find Output of Program (Q.No. 6)
6.
What will be the output of the program If characters 'a', 'b' and 'c' enter are supplied as input?
#include<stdio.h>

int main()
{
    void fun();
    fun();
    printf("\n");
    return 0;
}
void fun()
{
    char c;
    if((c = getchar())!= '\n')
        fun();
    printf("%c", c);
}
abc abc
bca
Infinite loop
cba
Answer: Option
Explanation:

Step 1: void fun(); This is the prototype for the function fun().

Step 2: fun(); The function fun() is called here.

The function fun() gets a character input and the input is terminated by an enter key(New line character). It prints the given character in the reverse order.

The given input characters are "abc"

Output: cba

Discussion:
31 comments Page 3 of 4.

Priyanka said:   1 decade ago
Its an recursion.
In recursion stack fill as like staircase.

So as by it executing stack become empty.
As stack empty it is in FILO means which is first in is get last out.

So it prints reverse.

Anjan said:   1 decade ago
How %c can printing 3 value. I know it is childish question but please help me.

Manish said:   1 decade ago
@Shubh.

getchar() will take one character as input and matches it with \n and then make a recursive call if condition is satisfied.

Shubh said:   1 decade ago
I am still not understanding this program.
When does it asks to enter the character?
There is no printf statemnt asking the user to enter the character.
Someone please clear my this doubt.

@Kamal Dua:
As per your explanation, you said at 4th recursive call, the condition satisfies. How come at 4th? There is no. number 4 in the condition.

Hey can anyone clear it in more detailed way?

Thank You.

Navdeep Jain said:   1 decade ago
Its very simple if you have studied a little bit about STACKS.

Stack work in LIFO (Last In First Out) policy.

So, lets look at Push process -

First input, "a"
Second input, "b"
Last input, "c"

Now, Pop one by one and you get "cba".

Rohan said:   1 decade ago
Thanks kamal.

Kamal dua said:   1 decade ago
It is based on flow of control.

Firstly in function fun() 'a' is entered then condition is checked. as it is not equal to '\0' so again fun() is called and this time 'b' is entered. similarly 'c' and at last in 4th recursive call of fuction fun()when enter is pressed, condition satisfies. so cursor goes to next line. now contol goes back to 3rd call of fun() in which c='c'.

Similarly control goes back to 2nd and 1st fun() call in which 'b' and 'a' get printed.

Reshma said:   1 decade ago
Can anybody tell me how abc is reversed to cba ?

Sagar Kapadiya(Surat) said:   1 decade ago
Can you describe a whole program?

Sundar said:   1 decade ago
@All

In Turbo C, I have compiled the program myprogram.c and executed as given below.

C:\Turboc>myprogram.exe
kumar
ramuk

C:\Turboc>myprogram.exe
sundar kumar
ramuk radnus

C:\Turboc> _


Note: Give the input by simply typing any string and press .

The given program prints the given string in reversed order.

I hope this example will help you. Have a nice day!


Post your comments here:

Your comments will be displayed after verification.