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

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

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

симметричность строки на С++ - C++

27.03.2013, 12:58. Просмотров 825. Ответов 1
Метки нет (Все метки)

Описать рекурсивную функцию, проверяющую, является ли симметричной часть строки s, начинающаяся i-м и заканчивающаяся j-м ее эле-ментами.

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
#include <iostream.h>
#include <conio.h>
#include <math.h>
 
 
bool recurs(char *b, int i)
{
 
   if( i <= 1 ) return true;
   if( *b == *(b+i-1) ) return  recurs( b + 1, i - 2 );
   return false;
 
 
        return 0;
}
void main()
{
    char a[255];
 
    int i,j;
    cout<<"Vvedite stroku: \n";
    cin.getline(a,255);
    do{
        cout<<endl<<"Vvedite i:"<<endl;
        cin>>i;
        cout<<"Vvedite j:"<<endl;
        cin>>j;
 
        if (i>j)
        {
            cout<<"oshibka vvoda.i>j."<<endl;
        }
    }while(i>j);
        int size=j-i;
        char* b = new char[j-i];
             for (int k=0; k<=size;k++){
                *(b+k) = '\0';
        }
        for (int k=0; k<size;k++){
                *(b+k) = a[i];
                i++;
        }
cout<<"Poluhennay stroka" << endl;
cout<<endl<<b;
 
 
    if (recurs(b,i) == true) cout<<endl<<"Stroka simetricna.";
    else cout<<endl<<"Stroka ne simetricna.";
    getch();
}

Не получаеться заставить программу проверять на симметричность
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
27.03.2013, 12:58     симметричность строки на С++
Посмотрите здесь:

Проверка на симметричность слова C++
C++ Проверка квадратной матрицы на симметричность
симметричность матрицы C++
C++ Проверьте симметричность
C++ Симметричность массива
C++ Симметричность массива
Симметричность матрицы C++
C++ Симметричность матрицы
Проверка строки на симметричность через рекурсию C++
C++ Проверка последовательности символов на симметричность
Проверить k строку массива N*M на симметричность C++
Объяснить код проверки строки на симметричность C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
lemegeton
2917 / 1346 / 133
Регистрация: 29.11.2010
Сообщений: 2,720
27.03.2013, 15:28     симметричность строки на С++ #2
Допиливайте как желаете:
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
#include <iostream>
#include <cstring>
 
// проверяет строку на симметричность
// строка задается адресом превого символа и
// адресом последнего символа
// функция возвращает истину, если строка является
// палиндромом
bool isPalindrome(const char *begin, const char *end) {
  while (begin < end) {
    if (*begin++ != *end--) {
      return false;
    }
  }
  return true;
};
 
int main(int argc, char *argv[]) {
 
  const char string[] = "arozaupalanalapuazora"; // строка
  int first = 3; // позиция первого символа с нуля
  int last = 17; // позиция последнего символа с нуля
 
  // выводит 1, если строка является палиндромом
  std::cout << isPalindrome(string + first, string + last) << std::endl;
  
  std::cin.get();
  return 0;
}
Добавлено через 3 минуты
Пардон, не заметил про рекурсию:
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
#include <iostream>
#include <cstring>
 
// проверяет строку на симметричность
// строка задается адресом превого символа и
// адресом последнего символа
// функция возвращает истину, если строка является
// палиндромом
bool isPalindrome(const char *begin, const char *end) {
  if (begin < end) {
    if (*begin != *end) {
      return false;
    } else {
      return isPalindrome(begin + 1, end - 1);
    }
  } else {
    return true;
  }
};
 
int main(int argc, char *argv[]) {
 
  const char string[] = "arozaupalanalapuazora"; // строка
  int first = 3; // позиция первого символа с нуля
  int last = 17; // позиция последнего символа с нуля
 
  // выводит 1, если строка является палиндромом
  std::cout << isPalindrome(string + first, string + last) << std::endl;
  // выводит 0, если строка не является палиндромом
  std::cout << isPalindrome(string + first, string + last + 1) << std::endl;
  
  std::cin.get();
  return 0;
}
Yandex
Объявления
27.03.2013, 15:28     симметричность строки на С++
Ответ Создать тему
Опции темы

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