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

Двунаправленный ассоциативный контейнер для хранения структур - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Работа с файлом http://www.cyberforum.ru/cpp/thread212600.html
В файле даны буквы. Вывести их в другой файл так,чтобы в 1-ой строке была одна буква,во 2-ой две буквы,в 3-ей три и тд.В последней строке оставшиеся буквы.Библиотека "fstream.h" Например: ...
C++ Оператор While срочно!!! Даны целые положительные числа N и K. Используя только операции сложения и вычитания, найти частное от деления нацело N на K, а также остаток от этого деления. http://www.cyberforum.ru/cpp/thread212583.html
C++ Beginning C++ Game Programming
У меня несколько вопросов по поводу этой книги. 1. Хорошая ли книга 2. На коком уровне нужно быть чтобы имело смысл читать
Обработка динамических матриц C++
Помогите пожалуйста, нужно решить задачу: Найти в матрице первую строку, все элементы которой упорядочены по возрастанию. Изменить упорядоченность элементов этой строки на обратную.
C++ работа с файлом http://www.cyberforum.ru/cpp/thread212344.html
дан строковой файл, содержащий упорядоченный по алфавиту список жителей района с указанием фамилии и инициалов. Вывести список неповторяющихся фамилий. Учесть что однаяаться окончанием
C++ Расчет сетевого графа Народ помогите программно реализовать расчет сетевого графа с выделением критического пути. Хоть какой алгоритм использовать вообще не знаю как делать. Зарание благодарен. подробнее

Показать сообщение отдельно
IROKEZ
0 / 0 / 0
Регистрация: 18.04.2010
Сообщений: 19
16.12.2010, 23:03  [ТС]
Цитата Сообщение от lemegeton Посмотреть сообщение
Есть подозрение, что это двусвязный список.
Ошибочное подозрение.
Это должно быть что-то вроде std::map (по смыслу, а не по реализации), но с возможностью поиска и по ключу и по значению. Для того чтобы реализовать такое нужно использовать 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
#include <iostream>
#include <assert.h>
using namespace std;
 
class Massive
{
public:
    Massive();
    ~Massive();
    void getElement(int N);
    void setElement(char *NAME, int num, int N);
    void setSize(int N);
    void getSize(int &N);
private:
    struct PhoneBook {
        char *name;
        int number;
    } *PhoneBookTab;
    int N;
};
 
Massive::Massive()
{
    N=0;
    PhoneBookTab=NULL;
}
 
Massive::~Massive()
{
    delete []PhoneBookTab;
}
 
void Massive::getElement(int n)
{
    assert(n>=0 && n<=N);
    cout
            << PhoneBookTab[n].name << "\n"
            << PhoneBookTab[n].number << endl << "\n";
 
    //return PhoneBookTab[n];
}
 
void Massive::setElement(char *NAME, int num, int n)
{
    assert(n>=0 && n<=N);
    PhoneBookTab[n].name=NAME;
    PhoneBookTab[n].number=num;
}
 
void Massive::setSize(int lenght)
{
    assert(lenght>=0);
    delete[] PhoneBookTab;
    PhoneBookTab = new PhoneBook[lenght];
 
    N=lenght;
}
 
void Massive::getSize(int &lenght)
{
    lenght=N;
}
 
int main()
{
    Massive tab;
    int n, num;
    char NAME[100];
 
    cout<<"Input number: ";
    cin>>n;
 
    tab.setSize(n);
    for(int i=0; i<n; i++)
    {
        cout << "Input name of abonent: ";
        cin >> NAME;
        cout << "Input tel number: ";
        cin >> num;
        tab.setElement(NAME, num, i);
    }
 
    for(int i=0; i<n; i++)
        tab.getElement(i);
 
 
    return 0; 
}
0
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru