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

Ошибка при компиляции виртуальные функции - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ "Не хочу константу!" http://www.cyberforum.ru/cpp-beginners/thread362459.html
Здравствуйте. Компилятор (пишу в wxDev-C++) ругается на такой код #ifndef LIFE_H #define LIFE_H class Life { public: Life (); // конструктор int around ( int, int ); // считает, сколько клеток вокруг
C++ помогите разобраться с библиотекой и в чем ошибка? Это метод Якоби #include "stdafx.h" #include <math.h> #include "nrutil.h" /* Здесь определяются некоторые утилиты типа выделения памяти */ /* Преобразование элементов при ротации */ #define ROTATE(a,i,j,k,l) g=a;h=a;a=g-s*(h+g*tau);a=h+s*(g-h*tau) /* максимальное число проходов */ #define MAXSWEEP 50 http://www.cyberforum.ru/cpp-beginners/thread362458.html
поиск в ширину(Рекурсивный) C++
Программа запускается но выдает ошибку(Задача такая: Создать программу для решения задачи построения слова из некоторого множества букв (игра Scrabble) используя алгоритмы поиска в глубину и в ширину. Длина слова не менее 5 букв. ) Код программы #include "stdafx.h" #include <iostream> #include <string> #include <Windows.h> using namespace std; string str1 = "forum"; // string str2...
C++ рекурсивные классы
Доброго времени суток. Скажите пожалуйста, можно ли при написании класса объявить в нём поле того же типа что и сам класс? Компилятор ругается на такое, но может это возможно по другому? class car { ... car lada; ... };
C++ Помогите с задачками http://www.cyberforum.ru/cpp-beginners/thread362411.html
16. В заданный текст входят только цифры и буквы. Определить, яв-ляется ли текст десятичной, шестнадцатеричной или двоичной записью целого либо вещественного числа (указать при выводе какого). 16. В файле Y1 задана матрица вещественных чисел. Сформировать файл Y2, в котором строки матрицы упорядочены по убыванию элементов первого столбца. 16. Дан список студентов группы. Заполнить его...
C++ Сформировать массив из элементов матрицы Из заданного массива А получить массив В попарно переставив первый и последний столбец, второй и предпоследней и т.д. подробнее

Показать сообщение отдельно
Sylvos
-25 / 6 / 1
Регистрация: 06.04.2011
Сообщений: 85
06.10.2011, 23:24     Ошибка при компиляции виртуальные функции
error LNK2001: неразрешенный внешний символ ""public: virtual float_thiscall Operator::getNumber(void)" (?getNubmer@Operator@@UAEMXZ)"

error LNK2001: неразрешенный внешний символ ""public: virtual char_thiscall Number::getOperator(void)" (?getOperator@Number@@UAEMXZ)"

error LNK1120: 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
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
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
#include<iostream>
#include<cstring>
using namespace std;
 
const int LEN=80;
const int MAX=100;
 
class Token
{
public:
    virtual char getOperator()=0;
    virtual float getNumber()=0;
};
 
class Operator:public Token
{
private:
    char oper;
public:
    Operator(char a)
    {
        oper=a;
    }
    char getOperator()
    {
        return oper;
    }
    float getNumber();
};
 
class Number:public Token
{
private:
    float fnum;
public:
    Number(float a)
    {
        fnum=a;
    }
    float getNumber()
    {
        return fnum;
    }
    char getOperator();
};
 
class Stack
{
private:
    Token *st[MAX];
    int top;
public:
    Stack()
    {
        top=0;
    }
    void push(char var)
    {
        st[++top]=new Operator(var);
    }
    void push(float var)
    {
        st[++top]=new Number(var);
    }
    Token* pop()
    {
        return st[top--];
    }
    int gettop()
    {
        return top;
    }
};
 
class express
{
private:
    Stack s;
    char* pStr;
    int len;
public:
    express(char*ptr)
    {
        pStr=ptr;
        len=strlen(pStr);
    }
    void parse()
    {
        float F=0;
        int C=0,U=10;
        char ch;
        Token* lastval;
        Token* lastop;
        for(int j=0;j<len;j++)
        {
            ch=pStr[j];
            if(ch>='0'&&ch<='9'&&C==0)
            {
                F=F*10+(ch-'0');
            }
            if(ch>='0'&&ch<='9'&&C==1)
            {
                F=F+(ch-'0')/U;
                U=U*10;
            }
            if(ch=='.')
                C=1;
            if(ch=='+'||ch=='-'||ch=='*'||ch=='/')
            {
                s.push(F);
                F=0;
                C=0;
                U=10;
 
                if(s.gettop()==1)
                    s.push(ch);
                else
                {
                    lastval=s.pop();
                    lastop=s.pop();
                    if((ch=='*'||ch=='/')&&(lastop->getOperator()=='+'||lastop->getOperator()=='-'))
                    {
                        s.push(lastop->getOperator());
                        s.push(lastop->getOperator());
                    }
                    else
                    {
                        switch(lastop->getOperator())
                        {
                            case'+': s.push(s.pop()->getNumber() + lastval->getNumber()); break;
                            case'-': s.push(s.pop()->getNumber() - lastval->getNumber()); break;
                            case'*': s.push(s.pop()->getNumber() * lastval->getNumber()); break;
                            case'/': s.push(s.pop()->getNumber() / lastval->getNumber()); break;
                            default: cout<<"Неизвестный оператор\n"; exit(1);
                        }
                    }
                    s.push(ch);
                }
            }
            else
            {
                cout<<"Неизвестные ввода символов\n";
                exit(1);
            }
        }
    }
    float solve()
    {
        Token* lastval;
        while(s.gettop()>1)
        {
            lastval=s.pop();
            switch(s.pop()->getOperator())
            {
                case'+': s.push(s.pop()->getNumber()+lastval->getNumber()); break;
                case'-': s.push(s.pop()->getNumber()-lastval->getNumber()); break;
                case'*': s.push(s.pop()->getNumber()*lastval->getNumber()); break;
                case'/': s.push(s.pop()->getNumber()/lastval->getNumber()); break;
                default: cout<<"Неизвестный оператор\n"; exit(1);
            }
        }
        return float(s.pop()->getNumber());
    }
};
int main()
{
    setlocale(LC_ALL,"Rus");
    char ans;
    char str[LEN];
    cout<<"Введите арифметическое выражение\n в виде 2+3*4/3-2.\n Никакое число не может иметь более одной цифры.\n Не используйте пробелы и круглые скобки.\n";
    do
    {
        cout<<"Введите выражение: ";
        cin>>str;
        express*eptr=new express(str);
        eptr->parse();
        cout<<"Численное значение: "<<eptr->solve()<<endl;
        delete eptr;
        cout<<"Сделать еще одно (Введите y или n)? ";
        cin>>ans;
    }
    while(ans=='y');
    return 0;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 01:13. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru