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

Калькулятор Страуструпа в класс - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ минимализация отходов http://www.cyberforum.ru/cpp-beginners/thread414100.html
Привет всем, есть некая задачка: дан прямоугольный лист(высота, ширина), даны разные фигурки(многогранные(не круглые), можно задавать точками), нужно наложить(вырезать) фигурки на лист так что бы площадь "отходов" с листа была минимальной... вот такая вот проблемка, может кто что подскажет в какую сторону копать?:scratch:
C++ Дан линейный массив A[1..N], содержащий целые числа. Найти те элементы массива, индексы которых являются полными квадратами. помогите плиз написать программу на С Дан линейный массив A, содержащий целые числа. Найти те элементы массива, индексы которых являются полными квадратами. http://www.cyberforum.ru/cpp-beginners/thread414091.html
Вывести в выходной файл монотонные слова C++
не могу найти ошибку в проге, помоги, плиз Входной файл состоит из одной строки. Размер строки не ограничен и её необходимо считывать поблочно по 1024 байта. Строка состоит из слов, разделенных пробелами. Каждое слово состоит из символов английского алфавита и имеет длину от 1 до 100. Гарантируется что между словами только один пробел и не используются другие знаки-разделители. Слово...
Просто позарез необходима поммощь! Молю, спасайте! Завтра зачёт... C++
такая прогарамма о графах и выскакивает всего одна ошибка на 1-ю строчку(#include "stdafx.h") Не удается открыть файл include: stdafx.h: No such file or directory Как исправить? #include "stdafx.h" #include<iostream> #include<conio.h> #include <stdio.h> #include <fstream>
C++ Метод Ньютона для решения систем нелинейных уравнений. http://www.cyberforum.ru/cpp-beginners/thread414085.html
Задание по курсовой работе заключается в следующем: даны координаты нескольки точек в трёхмерном пространстве а также расстояния до некоторых неизвестных точек. Все точки пронумерованы. Пример входных данных: ---для точек 1 2 3.5 5 - точка под номером один с координатами (2, 3.5, 5); ---для связей(расстояния между точками) 3 4 5.6 - расстояние между точками 3 и 4 равно 5.6. Так вот, к...
C++ Полиномы Помогите решить. Даны полиномы Pn(x)=a0+a1x+a2x^2+...+anx^n, Pm(x)=b0+b1x+b2X^2+...+bmx^m, 0<=m<=n<=10. Получить полином Pn(x)=d*Pm(x),где d - произвольное число. подробнее

Показать сообщение отдельно
vortexx1
 Аватар для vortexx1
6 / 6 / 2
Регистрация: 06.03.2011
Сообщений: 269
21.12.2011, 23:10     Калькулятор Страуструпа в класс
Здравствуйте. У меня есть рабочий код калькулятора Страуструпа. Как его так правильно переделать, чтобы использовался хотя бы один класс?

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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
#include <iostream>
#include <map>
#include <sstream>
#include <cctype>
 
enum Token_value {
        NAME, NUMBER, END,
        PLUS = '+', MINUS='-', MUL='*', DIV='/',
        PRINT=';', ASSIGN='=', LP='(', RP=')'
};
 
Token_value curr_tok=PRINT;
std::map<std::string,double> table;
double number_value;
std::string string_value;
int no_of_errors;
 
double error(const std::string& s){ 
        no_of_errors++;
        std::cerr << "error: " << s << std::endl;
        return 1;
}
 
Token_value get_token()
{
    char ch = 0;
    do {
        if (!std::cin.get(ch)) return curr_tok = END;
    } while (ch!='\n'&&isspace(ch));
 
    switch (ch) {
        case 0:
             return curr_tok = END;
        case ';':case '\n':
             return curr_tok = PRINT;
        case '*':case'/':case '+':case '-':case '(':case ')':case '=':
             return curr_tok=Token_value(ch);
        case '0':case '1':case '2':case '3':case '4' :
        case '5':case '6':case '7':case '8':case '9':case '.':
             std::cin.putback(ch);
             std::cin>>number_value;
             return curr_tok=NUMBER;
        default:
             if (isalpha(ch)) {
                 string_value = ch;
                 while (std::cin.get(ch)&&isalnum(ch)) string_value.push_back(ch);
                 std::cin.putback(ch);
                 return curr_tok = NAME;
             }
             error ("bad token");
             return curr_tok = PRINT;
    }
}
 
double expr(bool get);
double prim(bool get){
        if (get) get_token();
        switch (curr_tok){
        case NUMBER:{
                double v=number_value;
                get_token();
                return v;
        }
        case NAME:{
                double& v = table[string_value];
                if (get_token()==ASSIGN) v=expr(true);
                return v;
        }
        case MINUS:return -prim(true);
        case LP:{
                double e=expr(true);
                if (curr_tok!=RP) return error("')'expected");
                get_token();
                return e;
        }
        default:
                return error("primary expected");
        }
}
 
double term(bool get){
        double left=prim(get);
        for (;;)
                switch (curr_tok){
                 case MUL:
                         left*=prim(true);
                         break;
                 case DIV:
                         if (double d=prim(true)){
                                 left /= d;
                                 break;
                         }
                         return error("divide by 0");
 
                 default:return left;
                }
}
 
double expr(bool get){
        double left=term(get);
        for (;;)
                switch(curr_tok){
                case PLUS:
                        left+=term(true);
                        break;
                case MINUS:
                        left-=term(true);
                        break;
                default:
                        return left;
                }
}
 
int main() {
        table["pi"]=3.141592653589793;
        table["e"]=2.7182818284590452;
        while (std::cin){
                get_token();
                if (curr_tok==END) break;
                if (curr_tok==PRINT) continue;
                std::cout << expr(false) << std::endl;
        }
        return no_of_errors;
}
Спасибо.
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 05:30. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru