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

STL-контейнер.Переделать реализацию. - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Программа складывающая десятиричные и шестнадцатиричные числа http://www.cyberforum.ru/cpp-beginners/thread424316.html
Пожалуюста помогите написать программу сложения десятичного и шестнадцатиричного числа . Кто может посмотрите пожалуюста . А то завтра последний день сдачи :cry:
C++ Есть алгоритм. Помогите написать ПСЕВДОКОД Здравствуйте. Есть вот такой алгоритм поиска k-го минимума: АЛГОРИТМ: a1…an разбиваем на пятерки a1..a5 a6..a10 … an..an-1(за 9 действий, T(n/5)) Находим на этом множестве медиану... http://www.cyberforum.ru/cpp-beginners/thread424314.html
C++ Вывод 2 строк
Нужно вывести из файла 2 строки по 80 символов. не пойму как вывести.
Симплекс метод. Задача с двусторонними ограничениями C++
Нужна задачка, без разницы как реализована....главное чтобы работала. И именно не просто симлекс метод, а пример на задаче с двусторонними ограничениями!
C++ Дано значение угла alfa в радианах (0 < alfa < 2*pi). Определить значение этого же угла в градусах http://www.cyberforum.ru/cpp-beginners/thread424295.html
Здравствуйте я тока начинаю юзать с++ помоги пожалуйста заранее спасибо Дано значение угла alfa в радианах (0 < alfa < 2*pi). Определить значение этого же угла в градусах, учитывая, что 180° = pi...
C++ Вывести на экран 8 прямоугольников разного цвета на экран должно быть выведено 8 прямоугольников разного цвета. При нажатии на левую клавишу мыши прямоугольнк, в пределах которого находится курсор, должен сменить свойцвет на... подробнее

Показать сообщение отдельно
kobi23
1 / 1 / 0
Регистрация: 28.12.2011
Сообщений: 14

STL-контейнер.Переделать реализацию. - C++

08.01.2012, 13:36. Просмотров 709. Ответов 6
Метки (Все метки)

Ребята, написал прогу, в которой контейнер типа вектор хранит данные класса банк, и проводит с ними дейтвия, сортировка, поиск, добавление, НО ВСЯ РЕАЛИЗАЦИЯ В мейне, как сделать чтобы все было в отдельном классе, который обращался бы и к классу с данными и к STL. Например чтобы в мейне было вместо
C++
1
sort (BANK.rbegin(),BANK.rend(),compare());
было
C++
1
BANK.sorting();
Где sorting как раз функция того класса.

Весь код:
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
#include <iostream>
#include <vector>
#include <algorithm>
#include <string>
using namespace std;
 
class Bank//основной класс "Банк"
{
private:
    string bank;
    string klient;
    int ssuda;
    int vklad;
public:
    Bank():bank("nothing"),klient("nothing"),ssuda(0L),vklad(0L){} //конструктор по умолчанию
    Bank (string BANK, string KLIENT, int SSUDA, int VKLAD): //конструктор с 4-мя параметрами
    bank(BANK), klient(KLIENT),ssuda(SSUDA), vklad(VKLAD){}//заполнение конструктора
    friend bool operator < (const Bank, const Bank&);//перегрузка <
    friend bool operator ==(const Bank, const Bank&);//перегрузка ==
    friend bool operator !=(const Bank, const Bank&);//перегрузка !=
    friend bool operator >(const Bank, const Bank&);//перегрузка >
    void print()const {cout << "\n\n" << bank << " - " << klient //функция вывода всех данных
        << "\tVklad: " << vklad <<" rub"<< "\tssuda: "<<ssuda <<" rub\n";}
};
 
class compare //функциональный обьект для сортировки данных
{
public:
    bool operator() (const Bank odin, const Bank dva) const 
    {
        return odin < dva;
    }
};
 
class print_Bank //функиональный объект для вывода всех данных
{
public:
    void operator() (const Bank odin)const{odin.print();}
};
 
//перегрузка ==
bool operator ==(const Bank odin, const Bank &dva)
{
    return ((odin.bank == dva.bank)&&(odin.klient == dva.klient)) ?true:false;
}
//перегрузка <
bool operator <(const Bank odin, const Bank &dva)
{
    if (odin.bank == dva.bank)
        return (odin.klient < dva.klient) ?true:false;
    return (odin.bank < dva.bank) ?true:false;
}
//перегрузка !=
bool operator !=(const Bank odin, const Bank &dva)
{
    return !(odin==dva);
}
//перегрузка >
bool operator >(const Bank odin, const Bank &dva)
{
    return !(odin<dva) && !(odin==dva);
}
 
int main()
{
    cout << "--[Isxodnie dannie]--\n";
    
    vector <Bank> BANK;//создание контейнера типа вектор
    vector <Bank>::iterator iter;//создание итератора
    
    //зполнение данных в конец
    BANK.push_back(Bank("Sberbank","Abrmov",40000,100000));
    BANK.push_back(Bank("Tarhani","Volodin",10500,80000));
    BANK.push_back(Bank("Centrobank","Anisin",84560,220000));
    BANK.push_back(Bank("Kuzneckii","Voloshin",3000,15000));
    BANK.push_back(Bank("Sberbank","Kronov",99000,87200));
    BANK.push_back(Bank("Masterbank","Zolotov",456000,1000000));
    BANK.push_back(Bank("Maestro","Lebedev",21200,500000));
    
    for_each(BANK.begin(),BANK.end(),print_Bank());//вывод всех данных
    
    sort (BANK.rbegin(),BANK.rend(),compare());//сортировка данных по убыванию
    cout << "\n\n--[Otsortirovanie dannie]--\n";
    for_each(BANK.begin(),BANK.end(),print_Bank());
    
    //реализация поиска по банку и клиенту до первого вхождения
    string sBank, sKlient;
    cout << "\n\n--[Vvedite nazvanie banka]--\n";
    cin >> sBank; 
    cout << "\n--[Vvedite familiu klienta]--\n"; 
    cin >> sKlient; 
    Bank newBank(sBank, sKlient, 0L, 0L);//создани банка введенного с клавиатуры
    iter = find(BANK.begin(), BANK.end(), newBank);//поиск по листу первого вхождения искомого значения 
    if( iter != BANK.end() )
    {
        cout << "--[Rezultat poiska]--";
        (*iter).print(); 
    }
    else
    {
        cout << "--[Poisk ne dal rezultatov]--\n";
    }
    return 0;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru