Форум программистов, компьютерный форум CyberForum.ru
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
kryl1993
0 / 0 / 0
Регистрация: 06.06.2013
Сообщений: 6
#1

Рекурсивные функции (палиндром) - C++

07.06.2013, 09:53. Просмотров 630. Ответов 2
Метки нет (Все метки)

Необходимо составить программу, которая содержит рекурсивную функ-цию Palindrom(S) логического типа, возвращающую True, если строка S является палиндромом (то есть читается одинаково слева направо и справа налево), и False в противном случае. Оператор цикла в теле функции не использовать. Вывести значения функции Palindrom(S) для пяти данных строк.
Помогите плиз!
0
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
07.06.2013, 09:53
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Рекурсивные функции (палиндром) (C++):

Рекурсивные и не рекурсивные функции (вычисление суммы всех натуральных чисел от 1 до n) - C++
Всем привет. Заранее извиняюсь за мб глупые вопросы и навязчивость. Но у меня есть одна просьба. Помогите пожалуйста написать...

Рекурсивные функции - C++
Всем привет. Ребят, помогите. Задание: с помощью рекурсивной функции вычислить сумму элементов одномерного массива. Не спец в этом, задали...

Рекурсивные функции - C++
Плиз, помогите. Ошибку выдает, а исправить как - непонятно... Пока не очень понимаю рекурсивные функции... Составить программу,...

Рекурсивные функции. - C++
с самой функцией нет проблем проблема в самой программе задание звучит так Для заданных двух натуральных числа m и n найти НОД(m, n) и...

рекурсивные функции - C++
1. Найти НОД (наибольший общий делитель) двух натуральных чисел. 2. В одномерном массиве, состоящем из n целых элементов, вычислить номер...

рекурсивные функции - C++
Дано натуральные числа n,m ; найти НОД(наибольший общий делитель) . Использовать программу, которая содержит рекурсивную процедуру...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Мимино
180 / 151 / 5
Регистрация: 22.05.2013
Сообщений: 435
Записей в блоге: 1
07.06.2013, 10:08 #2
Цитата Сообщение от kryl1993 Посмотреть сообщение
Необходимо составить программу, которая содержит рекурсивную функ-цию Palindrom(S) логического типа, возвращающую True, если строка S является палиндромом (то есть читается одинаково слева направо и справа налево), и False в противном случае. Оператор цикла в теле функции не использовать. Вывести значения функции Palindrom(S) для пяти данных строк.
Помогите плиз!
Уже решал подобную задачу для строки "a roza upala na laru azora". Сложность заключается в игнорировании пробелов при сравнении. Вот что получилось:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
#include "stdafx.h"
#include <iostream>
using namespace std;
 
bool palindrom(char [], int);
 
int main()
{
    setlocale(LC_ALL, "Russian");
    char arr[27] = "a roza upala na lapu azora";
 
    cout << endl;
    if (palindrom(arr, 27) == true)
        cout << endl << endl << "Строка: " << arr << " - палиндром" << endl;
    else
        cout << endl << endl << "Строка: " << arr << " - не палиндром" << endl;
    system("pause");
    return 0;
}
 
 
bool palindrom(char a[], int size)
{
    int i = 0, j = 2;
 
    if (size - j <= 0)
        return true;
    else
    {
        if (a[i] == ' ')
            i++;
        if (a[size - j] == ' ' || a[size - j] == '\0')
            j++;
 
        cout << "a[" << i << "] = "<< a[i] << "   " << "a[" << size - j << "] = " << a[size - j] << "   " << "a[" 
                       << size - 1 << "] = " << a[size - 1] << endl;
        if (a[size - j] == a[i])
        {
            if (i == 1)
                j++;
            palindrom(&a[i + 1], size - j);
            if (size - j <= 0)
                return true;
        }
        else
            if (a[size - j] != a[i])
                return false;
            else
                return true;
    }
}
Я не пробовал, но уверен, что можно переделать под любую строку.
1
DarkSkazochnik
3 / 3 / 0
Регистрация: 17.11.2012
Сообщений: 39
07.06.2013, 10:32 #3
На самом деле достаточно просто:

1. Функция может возвращать тип bool (Boolean), т.о. мы можем обеспечить уверенный досрочный выход из рекурсии, наподобие следующего:

C++
1
2
3
4
5
6
7
8
9
10
bool recursion (bla bla bla) {
 
// Здесь какая-то проверка, пусть в переменную flag при неудаче передастся значение false.
 
bool flag2 = recursion (bla bla bla);
 
if (flag2 == flase) return;
else //обработка успешного результата.
 
}
2. Пробелы следует игнорировать. Для этого достаточно вспомнить что из себя представляет строка - массив символов с индексами от 0 до (size - 1) (т.е. если мы пишем char c[10], то обращение происходит только по индексам от 0 до 9 (10 - 1)). Отсюда выходит следующее:
а) Если элемент - пробел, переходим на следующий (предыдущий за ним) элемент
б) В функцию надо передать ещё 2 параметра - индекс позиции элемента в начале и конце.

P.S. просто надо уезжать, не могу написать подробнее, максимум если только вечером
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
07.06.2013, 10:32
Привет! Вот еще темы с ответами:

Рекурсивные функции - C++
Помогите пожалуйста написать программу! Разработать рекурсивную функцию, возвращающую значение для вычисления суммы цифр в строке. С...

рекурсивные функции - C++
помогите ррешить!!!!! на С++ Записать алгоритм Евклида вычисления наибольшего общего делителя (НОД) как рекурсивную функцию. Алгоритм...

Рекурсивные функции - C++
в функции мейн обьявить двумерный массив размером A заполнить случайным образом 1 и 2, вывести масив на экран написать рекурсивную...

рекурсивные функции - C++
Величайшие умы форума помагите пожалуйсто) Задание:Используя рекурсивную функцию, найдите n-й член арифметической прогрессии с...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru