0 / 0 / 0
Регистрация: 14.05.2015
Сообщений: 2
1

Проверка баланса скобок арифметического выражения, введенного с клавиатуры

14.05.2015, 21:07. Показов 2460. Ответов 1
Метки нет (Все метки)

Составить программу проверки баланса скобок арифметического выражения , введенного с клавиатуры.
__________________
Помощь в написании контрольных, курсовых и дипломных работ, диссертаций здесь
0
Лучшие ответы (1)
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
14.05.2015, 21:07
Ответы с готовыми решениями:

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

Проверка баланса скобок
#include<stdio.h> #include<string.h> struct NODE { char info; NODE *next; }; struct...

Проверка баланса скобок
Как задать условие в проверке баланса скобок, что если скобки окажутся НЕ пустыми, тое сть внутри...

Проверка баланса скобок
У меня есть вот такой код, но я не могу понять как он работает, не могли бы вы помочь мне с этим,...

1
-5 / 0 / 4
Регистрация: 12.01.2015
Сообщений: 54
15.05.2015, 22:55 2
Лучший ответ Сообщение было отмечено mashaxa как решение

Решение

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
#include "stdafx.h"
#include <iostream>
#include <string>
#include <stack>
 
using namespace std;
 
stack<char> sta;
 
bool checkString(string str)
{
    for(int i = 0; i < str.length(); ++i)
    {
        if ((str[i] =='(') || (str[i] =='{') || (str[i] =='['))
            sta.push(str[i]); //если скобка открывающая, то помещаем её в стек
        else
        { //если не открывающая
            if(sta.size() == 0) 
                return false; //если стек пуст, значит скобочная последовательность неправильная
            char c = sta.top(); //берём последнюю открывающую скобку
            sta.pop();
            if ((c == '(' && str[i] != ')') || (c == '{' && str[i] != '}') || (c == '[' && str[i] != ']'))  //если тип последней открывающей скобки не совпадает с текущей закрывающей, то скобочная последовательность неправильная  
                return false;
        }
    }
    return (sta.size() == 0); //если после обработки строки остались незакрытые скобки, то скобочная последовательность неправильная
}
void main()
{
    string str;
    int oper;
    cout<<"Enter a 1 to continue or 0 to exit:"<<endl; cin>>oper; //используем
оператор switch для возможности ввода другой строки или выхода
    do{//повторяем до тех пор, пока пользователь не введёт 0
        switch(oper)
        {
        case 1:
            cout<<"Enter a string: "; cin>>str; //заполняем строку
            if(checkString(str)) cout << "Correct arithmetic expression" << endl; //проверяем на коррекность введённой последовательности скобок и выводим результат
            else cout << "Impossible to make an expression" << endl;
            cout<<"Enter a 1 to continue or 0 to exit:"<<endl; cin>>oper;
            break;
        }
    }
    while (oper!=0);
    system("pause");
}
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
15.05.2015, 22:55
Помогаю со студенческими работами здесь

Проверка баланса скобок
Здравствуйте! Помогите пожалуйста со следующей задачкой. Необходимо написать код с помощью...

Строки: проверка баланса скобок
Проверить баланс скобок в выражении.

Проверка баланса расстановки скобок
Разработать и испытать функцию для проверки баланса парных скобок в строке, то есть количество...

Проверка баланса скобок в арифметическом выражении
Задано арифметическое выражение. Проанализировать баланс скобок ( ), , {}, используя стек. Я...


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

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

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2023, CyberForum.ru