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

Многофайловой проект и STL - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Абстрактный класс и std::sort http://www.cyberforum.ru/cpp-beginners/thread950169.html
Добрый день, Не компилируется строка: std::vector<mtl::io::QtFile*> *vec; ... mtl::misc::Sort(vec); // ЭТА СТРОКА Компилятор (g++ 4.7.3 Ubuntu) выдает: error: cannot convert ‘std::vector<mtl::io::QtFile*>*’ to ‘std::vector<mtl::misc::Sortable*>*’ for argument ‘1’ to ‘void mtl::misc::Sort(std::vector<mtl::misc::Sortable*>*)’
C++ масив структур Создать масив структур, каждая с которых состоит с селементов: факультет, курс, група, фамилии студентов, оценки, стипендия. Определить: 1) фамилии студентов со степухой и их средний бал. 2)факультет, где на первом курсе наименее двоишников. 3)курс с наибольшим количеством отличников. Помогите сделать програму. Только недавно начал учить С++, но еще не успел усвоить даную тему, а мой препод... http://www.cyberforum.ru/cpp-beginners/thread950167.html
C++ Работа конструкторов в классе и дружественная функция
Есть програмка с классом Meal. К ней я так же написал дружественную функцию с вычитанием калорийности объектов от общей калорийности, но расчеты получаются не правильными. Вот сам текст класса: #include <iostream> #include <conio.h> using namespace std; class Meal{ private: double Carrot; double Kap; double Meat;
C++ Матрицы. Найти элементы, меньшие среднего арифметического
Вот задача, мне срочно нужна ваша помощь... С клавиатуры вводится размерность целочисленной матрицы, затем сама матрица. Найти элементы меньшие среднего арифметического. Разрешается при этом использовать только один оператор цикла (кроме цикла ввода матрицы). на выходе выводится меньшее число с индексом. С комментариями пожалуйста, потому что я вообще не изучала этот язык...
C++ указатели и шаблоны http://www.cyberforum.ru/cpp-beginners/thread950141.html
Добрый день. Есть вот такой шаблон template< typename T> struct A{ void a(){} }; в одной части программы он возможен или как
C++ Нахождение углов треугольника по трем его сторонам На данный момент у меня получается вот так.. На форуме есть подобная тема но она на языке паскаль http://www.cyberforum.ru/pascal/thread91176.html #include "stdafx.h" #include "math.h" #include <iostream> using namespace std; int main() { double a,b,c,S,u; подробнее

Показать сообщение отдельно
o33ik
138 / 5 / 1
Регистрация: 25.03.2013
Сообщений: 228

Многофайловой проект и STL - C++

08.09.2013, 13:41. Просмотров 345. Ответов 9
Метки (Все метки)

Надо написать программу, в которой будут использоваться контейнеры STL(пока написал список). И для каждого контейнера будет свой файл в проекте. Сначала все писал в один файл. Для списка сделал все что требовало задание. Я попробовал свой класс(написал свой класс, в нем есть поле - СТЛовский список) запихнуть в отдельные .h и .cpp файлы. Я раньше делал программу таким способом и она работала, поетому сделать ето было не сложно. Но наверное из за использования шаблона, у меня что то не сраслось. В строке обьявления списка(sourse_list.h - 4 строка) нашло 6 ошибок, хотя ошибки странные. вроде не ошибки, а компилятор говорит что ошибки. Ну, и следовательно из за етих "ошибок" в soure_list.cрр нашло еще 33-35 ошибок с неизвесными иденфикаторами. В чем проблема, я не могу понять.

sourse_m.cpp - главный файл
C++
1
2
3
4
5
6
7
8
9
10
11
#include <iostream>
#include "sourse_list.h";
 
using namespace std;
 
 
void main()
{
    my_list obj;
    obj.MENU(obj);
}
sourse_list.h тут я обьявил класс: одне поле и несколько методов
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
class my_list
{
private:
    list<double>mylist; // тут 6 ошибок находит компилятор
public:
    void MENU(my_list obj);
    void add_f();
    void add_b();
    void pop_f();
    void pop_b();
    void show_l();
    void out_l();
    void ser_arif();
    void del_from_diap();
};
sourse_list.cpp - тут описан класс
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
#include "sourse_list.h";
#include <list>;
#include <iostream>;
 
using namespace std;
 
void my_list::MENU(my_list obj)
{
    while(true)
    {
        cout << "\n\t\t\tMENU\n\t1)ADD FRONT;\n\t2)ADD BACK;\n\t3)POP FRONT;\n\t4)POP BACK;\n\t5)SHOW LIST;\n\t6)OUT LIST;\n\t7)DETERMINE THE AVERAGE ARITHMETIC AND PUSH IT IN THE BOTTOM OF THE LIST;\n\t8)REMOVE ITEMS FROM THE SPECIFIED RANGE;\n";
        cout << "\tEnter key:";
        int key;
        cin >> key;
        switch(key)
        {
            case 1: obj.add_f(); break;
            case 2: obj.add_b(); break;
            case 3: obj.pop_f(); break;
            case 4: obj.pop_b(); break;
            case 5: obj.show_l(); break;
            case 6: obj.out_l(); break;
            case 7: obj.ser_arif();break;
            case 8: obj.del_from_diap(); break;
            default: continue;
        }
    system("cls");
    }
}
void my_list::add_f()
{
    cout << "\nFUNCTION PUSH_FRONT FOR A LIST";
    double val;
    while(true)
    {
        cout << "\nEnter value: ";
        cin >> val;
        mylist.push_front(val);
        char Q = 'y';
        while(true)
        {
            cout << "\nContinue(y/n)?";
            cin >> Q;
            if (Q == 'y')
                break;
            if (Q == 'n')
                break;
            else
            {
                cout << "\nError! Invalid choise. Try again";
                continue;
            }
        }
        if (Q == 'n') 
            break;
    }
}
void my_list::add_b()
{
    cout << "\nFUNCTION PUSH_BACK FOR A LIST";
    double val;
    while(true)
    {
        cout << "\nEnter value: ";
        cin >> val;
        mylist.push_back(val);
        char Q = 'y';
        while(true)
        {
            cout << "\nContinue(y/n)?";
            cin >> Q;
            if (Q == 'y')
                break;
            if (Q == 'n')
                break;
            else
            {
                cout << "\nError! Invalid choise. Try again";
                continue;
            }
        }
        if (Q == 'n') 
            break;
    }
}
void my_list::pop_f()
{
    if (mylist.size()==0)
        cout << "\nError! List is empty.\n";
    else
    {
        cout << "\nFUNCTION POP_FRONT FOR A LIST\n";
        mylist.pop_front();
    }
}
void my_list::pop_b()
{
    if (mylist.size()==0)
        cout << "\nError! List is empty.\n";
    else
    {
        cout << "\nFUNCTION POP_FRONT FOR A LIST\n";
        mylist.pop_back();
    }
}
void my_list::show_l()
{
    if (mylist.size()==0)
        cout << "\nError! List is empty.\n";
    else
    {
         list<double> mylist_tmp = mylist;
         int size = mylist_tmp.size();
         for(int j = 0; j < size; j++)       
         {  
            cout << mylist_tmp.front() << ' ';
            mylist_tmp.pop_front();
         } 
    }
    system("pause");
}
void my_list::out_l()
{
    if (mylist.size()==0)
        cout << "\nError! List is empty.\n";
    else
    {
         int size = mylist.size();
         for(int j = 0; j < size; j++)       
         {  
            cout << mylist.front() << ' ';
            mylist.pop_front();
         } 
    }
    system("pause");
}
void my_list::ser_arif()
{
    double sum=0;
    list<double> mylist_tmp = mylist;
    int size = mylist_tmp.size();
        for(int j = 0; j < size; j++)       
    {  
        sum = sum + mylist_tmp.front();     
        mylist_tmp.pop_front();             
    }
    mylist.push_back(sum);
    cout << "\nSum = " << sum << endl;
    system("pause");
}
void my_list::del_from_diap()
{
    double a,b;
    cout << "\nEnter diapason: \n";
    cin >> a >> b;
    if (a > b)
        swap(a,b);
    list<double> mylist_tmp = mylist;
    int size = mylist.size();
    for (int i = 0; i < size; i++)
    {
        mylist.pop_front();
    }
    
    for (int i = 0; i < size; i++)
    {
        if (mylist_tmp.front() >= a && mylist_tmp.front() <= b)
            mylist_tmp.pop_front();
        else 
        {
            double TMP = mylist_tmp.front();
            mylist.push_back(TMP);
            mylist_tmp.pop_front();
        }
    }
};
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru