Форум программистов, компьютерный форум, киберфорум
Наши страницы
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
marymap
2 / 2 / 1
Регистрация: 28.11.2016
Сообщений: 80
1

Проверить правильность расстановки в тексте круглых скобок. Текст заканчивается точкой

28.11.2016, 21:29. Просмотров 264. Ответов 1
Метки нет (Все метки)

Работает,но неправильно. Сделала конечным автоматом. Помогите, пожалуйста!

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
#include <iostream>
#include <string>
#include <cmath>
using namespace std;
int main() {
enum {RB,LB,OTHER,POINT};
enum {START,HAS_B,NO_B,L_B,R_B,END,ERROR};
int text[3][6];
text[0][0]=HAS_B;
text[0][1]=ERROR;
text[0][2]=NO_B;
text[0][3]=END;
text[1][0]=R_B;
text[1][1]=L_B;
text[1][2]=HAS_B;
text[1][3]=ERROR;
text[2][0]=HAS_B;
text[2][1]=ERROR;
text[2][2]=NO_B;
text[2][3]=END;
text[3][0]=R_B;
text[3][1]=L_B;
text[3][2]=HAS_B;
text[3][3]=END;
text[4][0]=R_B;
text[4][1]=L_B;
text[4][2]=HAS_B;
text[4][3]=ERROR;
text[5][0]=ERROR;
text[5][1]=ERROR;
text[5][2]=ERROR;
text[5][3]=END;
text[6][0]=ERROR;
text[6][1]=ERROR;
text[6][2]=ERROR;
text[6][3]=ERROR;
int good_text ;
good_text= START;
char symbol=' ';
char dot='.';
char left_b=')';
char right_b='(';
int sum=0;
int s=0;
cout<<"enter text";
while ((good_text==ERROR)||(symbol!=dot))
{
cin>>symbol;
 if (symbol==right_b) { sum++;
s=RB;}
 else if (symbol==left_b) {sum--;
s=LB;}
else if (symbol==dot) s=POINT;
else s=OTHER;
good_text=text[good_text][s];}
if ((good_text==END)&& (s==0)) cout <<"correct";
else cout<< "not correct";
system("pause");
    return 0; 
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
28.11.2016, 21:29
Ответы с готовыми решениями:

Проверить правильность расстановки в тексте круглых скобок
Задача: Проверить правильность расстановки в тексте круглых скобок. ...

Проверить правильность расстановки в тексте круглых скобок (конечный автомат)
Только начала изучать С++.Необходимо проверить правильность расстановки в...

Дана строка символов проверить правильность расстановки круглых и квадратных скобок в выражениях
дана строка символов проверить правильность расстановки круглых и квадратных...

Проверить правильность расстановки и вложенности скобок в тексте (абстрактный стек)
реализовать с помощью связного списка...

Проверить в тексте файла правильность расстановки открывающих и закрывающих скобок
Помогите, пожалуйста написать программу C++ Дан текстовый файл INPUT.TXT....

1
Fixer_84
1049 / 659 / 651
Регистрация: 30.04.2016
Сообщений: 2,234
28.11.2016, 22:42 2
marymap, написал для вас код. Надеюсь, пригодится. Программа работает только для скобок. То есть вам просто нужно вытащить скобки из текста и подставить в функцию. Если не сможете, я помогу.

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
#include <iostream>
#include <string>
 
using namespace std;
 
int Braces(string s, char a, char b) //Функция обработки скобочной последовательности
{
int k, l;
l = s.length();
k = 0;
for (int i = 0; i < l; i++)
{
for (int j = i + 1; j < l; j++)
{
if (((s[i] == a) && (s[j] == b) && (i % 2 == 0) && (j % 2 != 0)) ||
    ((s[i] == a) && (s[j] == b) && (i % 2 != 0) && (j % 2 == 0)))
 
{
k++;
break;
}
}
}
return k;
}
 
int main()
{
int N, l;
string s;
getline(cin, s); //Вводим строку (только скобки)
l = s.length();
//Так через функцию можно добавить другие скобки не меняя код (они могут быть вложены друг в друга)
//N = Braces(s, '(', ')') + Braces(s, '[', ']') + Braces(s, '{', '}') + ...;)
//В вашем случае это просто '(' и ')'
N = Braces(s, '(', ')'); //Функция обработки скобочной последовательности
if (!(l % 2))
{
if ((l / 2) == N) cout << "CORRECT!" << endl;
else cout << "NOT CORRECT!" << endl;
}
else if (l % 2) cout << "NOT CORRECT!" << endl;
else if (s == "") cout << "CORRECT!" << endl;
system("pause");
return 0;
}
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
28.11.2016, 22:42

Написать рекурсивную функцию, проверяющую правильность расстановки круглых скобок в строке
Написать рекурсивную функцию, проверяющую правильность расстановки круглых...

Использование стека. Дана строка символов. Проверьте правильность расстановки в ней круглых скобок.
Использую пример программы от сюда:...

Проверить правильность расположения круглых скобок
Пусть задано множество строк. Проверить правильность расположения круглых...


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

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

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