Ir para conteúdo
Fórum Script Brasil
  • 0

Matheus22

Pergunta

Olá, antes de mais nada gostaria de dizer obrigado a quem responder minha dúvida. Bom eu estou aprendendo a linguagem C, e em um dos livros que estou lendo, vi um código que utiliza a recursividade para inverter uma string:

#include <stdio.h>
#define SIZE 80
void reverse( const char * const sPtr ); // prototype
int main( void )
{
   char sentence[ SIZE ]; // create char array
   puts( "Enter a line of text:" );
   // use fgets to read line of text
   fgets( sentence, SIZE, stdin );
   puts( "\nThe line printed backward is:" );
   reverse( sentence );
} // end main
// recursively outputs characters in string in reverse order
void reverse( const char * const sPtr )
{
   // if end of the string
   if ( '\0' == sPtr[ 0 ] ) { // base case
      return;
      } // end if
      else { // if not end of the string
           reverse( &sPtr[ 1 ] ); // recursion step
           putchar( sPtr[ 0 ] ); // use putchar to display character 
      } // end else
} // end function reverse

Código retirado do livro: C - How to Program 7th edition, página: 347, autor: Deitel.

Minha dúvida é a seguinte: como a função "reverse" funciona? Algúem pode me explicar detalhadamente? Porque não consegui entender como ela inverte um string, sendo que na linha: 21, a chamada "reverse" é chamada e recebe como argumento o endereço de memória do segundo espaço do array "sentence", e eu imagino, como ela inverte um string sendo que na próxima chamada recursiva, ela vai receber novamente "o endereço de memória do segundo espaço do array(sentence)".

Desde já agradeço a qualquer um que se comprometer a sanar minha dúvida.

Editado por Matheus22
Correções.
Link para o comentário
Compartilhar em outros sites

0 respostass a esta questão

Posts Recomendados

Até agora não há respostas para essa pergunta

Participe da discussão

Você pode postar agora e se registrar depois. Se você já tem uma conta, acesse agora para postar com sua conta.

Visitante
Responder esta pergunta...

×   Você colou conteúdo com formatação.   Remover formatação

  Apenas 75 emoticons são permitidos.

×   Seu link foi incorporado automaticamente.   Exibir como um link em vez disso

×   Seu conteúdo anterior foi restaurado.   Limpar Editor

×   Você não pode colar imagens diretamente. Carregar ou inserir imagens do URL.



  • Estatísticas dos Fóruns

    • Tópicos
      152,3k
    • Posts
      652,6k
×
×
  • Criar Novo...