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

Рекурсия (проверка на предмет соответствия закрывающих и открывающих скобок) - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Вычислить и вывести на экран значения функции в зависимости от входного значения Х http://www.cyberforum.ru/cpp-beginners/thread797646.html
Вычислить и вывести на экран значения функции в зависимости от входного значения Х. заранее благодарю :sorry:
C++ Заполнение массива с клавиатуры Уважаемые программисты,может ли кто-нибудь помочь,вот код: #include <cstdlib> #include <iostream> using namespace std; #pragma once class CN { http://www.cyberforum.ru/cpp-beginners/thread797640.html
Построчное считывание из файла C++
#include <stdio.h> #include <stdlib.h> #include <malloc.h> typedef struct { double x1; double y1; double x2; double y2;
Шаблон стека и перегрузка передачи в поток C++
Нужно написать шаблон стека с перегрузкой << и >> для ввода/вывода Внутри класса функция объявлена так: template<class Type> friend ostream& operator<<(ostream& out, const Stack<Type>&);...
C++ OpenGL в CodeBlocks http://www.cyberforum.ru/cpp-beginners/thread797631.html
Мучаюсь с установкой OpenGL в CodeBlocks уже целый вечер. Все нервы вытрепал. Пожалуйста опишите здесь по полочкам как установить OpenGL на CodeBlocks. Со всеми ссылками для скачивания, ибо я...
C++ Шаблон стека и перегрузка передачи в поток Нужно написать шаблон стека с перегрузкой << и >> для ввода/вывода Внутри класса функция объявлена так: template<class Type> friend ostream& operator<<(ostream& out, const Stack<Type>&); Сама... подробнее

Показать сообщение отдельно
anmartex
...
1708 / 1201 / 496
Регистрация: 12.02.2013
Сообщений: 1,978
01.03.2013, 19:46
kamre, это конечно здорово но:
  1. А где у вас рекурсия? Вы название темы читали?
  2. Здорово, что вы знаете boost, но я уверен, что автор темы про него слыхом не слыхивал. И я уверен, что вы это прекрасно понимаете. Так зачем же тогда, измените за жаргон, эти понты?

Bulding, в предыдущем алгоритме есть баг. Когда сейчас начал комментировать, понял, что я немного ошибся. Переделал немного и по вашей просьбе прокомментировал основные моменты.
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
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
#include <iostream>
#include <string>
#include <cstdlib>
 
bool IsRight(const char*& text, size_t current)
{
   // Я думаю и так понятно. Закономерность такая:
   // чётные - открывающиеся, нечётные - закрывающиеся
   static const std::string CBrackets = "{}[]()";
 
   bool isOk = true;
 
   // Начинаем перебирать все символы до тех пор, пока
   // не встретим 0 символ или пока не найдётся ошибка
   for (; *text && isOk; ++text)
   {
      // Пытаемся найти текущий символ в нашем списке скобок
      size_t find = CBrackets.find_first_of(*text);
 
      if (find != std::string::npos)
      {
         // В том случае если у нас открывающаяся скобка
         // то нужно искать закрывающуюся, т.е. вызываем
         // заново эту же функцию.
         if ((find % 2) == 0)
         {
            isOk = IsRight(++text, find);
         }
         // Если это закрывающаяся скобка
         else
         {
            // Ошибка будет в том случае, если открывающаяся
            // и закрывающаяся стоят не рядом.
            isOk = ((find - current) == 1);
 
            // current может быть равным std::string::npos
            // только в одном случае, если это самый первый вызов
            // функции. Т.е. это основной цикл поиска скобок.
            // А его как раз нужно выполнить до конца, ну а если это какой-то
            // повторный вызов и мы нашли и открывающуюся и закрывающуюся,
            // то просто возвращаем результат нашего поиска
            if (current != std::string::npos)
            {
               return isOk;
            }
         }
      }
   }
 
   // Если это был не самый первый вызов функции,
   // значит пара не была найдена, т.е. перебрали всё
   // а закрывающейся на каком-то этапе не выявили, значит
   // всё - провал
   if (current != std::string::npos)
   {
      isOk = false;
   }
 
   return isOk;
}
 
bool IsRight(const std::string& text)
{
   const char* txt = text.c_str();
 
   return IsRight(txt, std::string::npos);
}
 
int main(int argc, const char* argv[])
{
   std::string text;
   std::cout << "Input text: ";
   std::getline(std::cin, text);
 
   std::cout << (IsRight(text) ? "right" : "not right") << std::endl;
 
   system("PAUSE");
 
   return 0;
}
0
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru