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

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

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

рекурсивные функции C++
C++ рекурсивные функции
C++ Рекурсивные функции
Рекурсивные функции. C++
Рекурсивные функции C++
C++ Рекурсивные и не рекурсивные функции (вычисление суммы всех натуральных чисел от 1 до n)
C++ Рекурсивные функции
Рекурсивные функции C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Мимино
 Аватар для Мимино
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;
    }
}
Я не пробовал, но уверен, что можно переделать под любую строку.
DarkSkazochnik
 Аватар для 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. просто надо уезжать, не могу написать подробнее, максимум если только вечером
Yandex
Объявления
07.06.2013, 10:32     Рекурсивные функции (палиндром)
Ответ Создать тему
Опции темы

Текущее время: 07:03. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru