Member 13922884 Ответов: 3

Программа не печатает первый символ строки при использовании функции рекурсии.


//Реверсирование строки с помощью рекурсии
#включить<stdio.h>
#include<string.h>
пустота удовольствие(ул. гольца *);
пустота главная()
{
char str[30];
статический int i;
printf("введите строку:");
получает(str);
fun(&str[0]);
}
пустота удовольствие(ул. гольца *)
{
инт лен;
len=strlen(str);
если(лен)
{
ул. Веселой(++);
}
printf("\n %c",*str);

}

В соответствии с выводом printf() печатает значения после ++str, следовательно, опуская первый символ строки. Экс- "помоги мне" является строкой, то выход такой: эм апельсин.

Что я уже пробовал:

Но если я буду следовать этой простой программе, то выход будет 0123, и он не будет пропускать первое целое число.
пустота главная()
{
abc(3);
}
void abc(int a)
{
Если(а)
{
abc(a-1);
}
printf("%d",a);
}

Предложения, пожалуйста. Заранее спасибо.

3 Ответов

Рейтинг:
28

Rick York

Причиной этого является "++str". Размещение ++ первым означает, что он предварительно увеличивается. Указатель сначала увеличивается, а затем передается в fun. Вы можете обнаружить, что постинкрементирование-это то, что вам нужно здесь. Это будет "str++". Это увеличит str после того, как его значение будет помещено в стек.

Лично я не предпочитаю ни одну из этих конструкций, потому что их легко не заметить. Я бы написал это как два независимых оператора - сначала вызовите функцию, а затем увеличьте указатель.


Member 13922884

Спасибо. Теперь это работает.

Рейтинг:
0

Patrice T

Цитата:
Программа не печатает первый символ строки при использовании функции рекурсии.

Ваш код ведет себя не так, как вы ожидаете, или вы не понимаете, почему !

Существует почти универсальное решение: запускайте свой код на отладчике шаг за шагом, проверяйте переменные.
Отладчик здесь, чтобы показать вам, что делает ваш код, и ваша задача-сравнить с тем, что он должен делать.
В отладчике нет никакой магии, он не знает, что вы должны делать, он не находит ошибок, он просто помогает вам, показывая, что происходит. Когда код не делает того, что ожидается, вы близки к ошибке.
Чтобы увидеть, что делает ваш код: просто установите точку останова и посмотрите, как работает ваш код, отладчик позволит вам выполнять строки 1 на 1 и проверять переменные по мере их выполнения.

Обратная сторона этого решения:
- Это DIY, вы один отслеживаете проблему и находите ее корни, которые ведут к решению.
Положительная сторона этого решения:
- Это также отличный инструмент обучения, потому что он показывает вам реальность, и вы можете увидеть, какие ожидания соответствуют реальности.

Вторичное воздействие
- Вы будете гордиться тем, что сами находите Жуков.
- Ваши навыки обучения улучшатся.

Вы должны довольно быстро найти, что не так.

Отладчик - Википедия, свободная энциклопедия[^]

Освоение отладки в Visual Studio 2010 - руководство для начинающих[^]
Базовая отладка с помощью Visual Studio 2010 - YouTube[^]
1.11 — отладка программы (пошаговое выполнение и останова) | выучить C++[^]
Отладчик здесь только для того, чтобы показать вам, что делает ваш код, и ваша задача-сравнить его с тем, что он должен делать.


Member 13922884

Спасибо за ваше предложение. Я попробовал.

Рейтинг:
0

CPallini

Как указывалось выше Стог ++str это ошибка. Фокус в том, чтобы пройти мимо (str+1) для рекурсивного вызова попробуйте:

#include<stdio.h>

#define MAXLEN 30

void print_reversed(const char *str);

int main()
{
  char str[MAXLEN];
  printf("Enter a string:\n");
  fgets(str, MAXLEN, stdin);
  print_reversed(str);
  printf("\n");
  return 0;
}

void print_reversed(const char *str)
{
  if ( *str=='\n' || *str=='\0') return;
  print_reversed( str + 1);
  printf("%c",*str);
}


Member 13922884

Спасибо

CPallini

Добро пожаловать.

Member 13922884

Сегодня я попробовал использовать функцию fgets, но не в этой программе, а в какой-то другой, чтобы получить данные от пользователя. Но я обнаружил, что fgets() используется для чтения данных из файла. Как получилось, что вы используете его для получения данных от пользователя с помощью fgets().

CPallini

(Консоль) пользовательский ввод-это специальный файл (всегда открытый), вызывается соответствующий указатель файла stdin См., например::
https://www.tutorialspoint.com/cprogramming/c_input_output.htm

Member 13922884

Хорошо. Узнал что-то новое. Огромное спасибо !!

CPallini

Добро пожаловать.