Форум программистов, компьютерный форум 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)) Находим на этом множестве медиану медиан m Разбиваем массив на две части, первая часть не превосходит медиану, вторая больше медианы. Определяем, в какой из частей находится k-ый минимум, и запускаем данный алгоритм для этой части http://www.cyberforum.ru/cpp-beginners/thread424314.html
C++ Вывод 2 строк
Нужно вывести из файла 2 строки по 80 символов. не пойму как вывести.
Симплекс метод. Задача с двусторонними ограничениями C++
Нужна задачка, без разницы как реализована....главное чтобы работала. И именно не просто симлекс метод, а пример на задаче с двусторонними ограничениями!
C++/CLI WinForms С++ Крестики нолики http://www.cyberforum.ru/cpp-beginners/thread424303.html
мне нужно написать игру крестики нолики вот нарыл код в нем есть ошибки? помогиете плз я в этом не очень силён #pragma once namespace Крестикинолики { using namespace System; using namespace System::ComponentModel;
C++ Дано значение угла alfa в радианах (0 < alfa < 2*pi). Определить значение этого же угла в градусах Здравствуйте я тока начинаю юзать с++ помоги пожалуйста заранее спасибо Дано значение угла alfa в радианах (0 < alfa < 2*pi). Определить значение этого же угла в градусах, учитывая, что 180° = pi радианов. В качестве значения pi использовать 3.14. #include <stdio.h> #include <conio.h> main () { float x,a; clrscr (); printf ("Vvedite A:"); scanf ("%f",&a); подробнее

Показать сообщение отдельно
kobi23
1 / 1 / 0
Регистрация: 28.12.2011
Сообщений: 14
08.01.2012, 13:36     STL-контейнер.Переделать реализацию.
Ребята, написал прогу, в которой контейнер типа вектор хранит данные класса банк, и проводит с ними дейтвия, сортировка, поиск, добавление, НО ВСЯ РЕАЛИЗАЦИЯ В мейне, как сделать чтобы все было в отдельном классе, который обращался бы и к классу с данными и к 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;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 05:58. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru