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

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

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Работа с файлом http://www.cyberforum.ru/cpp/thread212600.html
В файле даны буквы. Вывести их в другой файл так,чтобы в 1-ой строке была одна буква,во 2-ой две буквы,в 3-ей три и тд.В последней строке оставшиеся буквы.Библиотека "fstream.h" Например: даны буквы a b c d e f g h i j k l должно получиться a b c ...
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

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

16.12.2010, 18:47. Просмотров 925. Ответов 2
Метки (Все метки)

12. Двунаправленный ассоциативный контейнер.

Цель: разработать программу, реализующую функционал телефонной книги.

Задачи:
12.1 Разработать структуру данных для хранения информации и контейнер для хранения структур данных.
12.2 На основе контейнера реализовать следующие операции:
- добавление абонента;
- удаление абонента;
- изменение информации об абоненте;
- поиск телефонного номера по имени абонента;
- поиск имени абонента по телефонному номеру.
12.3 Создать пользовательский интерфейс, позволяющий осуществлять поиск, отображение и редактирование данных об абоненте. Создать помощники (wizard) для добавления/удаления абонента.

Собственно интересует только первый пункт, т.к. остальное могу реализовать сам. Что такое двунаправленный ассоциативный контейнер я знаю. проблема состоит в том, что я не знаю как его правильно реализовать программно. У меня есть 2 варианта решения задачи: первый - через один массив, второй - через 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
#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()
{
    for(int i=0; i<N; i++)
        delete []PhoneBookTab;
}
 
void Massive::getElement(int 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);
    for(int i=0; i<N; i++)
        delete[] PhoneBookTab;
    PhoneBook *PhoneBookTab = new PhoneBook[lenght];
    N=lenght;
}
 
void Massive::getSize(int &lenght)
{
    N=lenght;
}
 
int main()
{
    Massive tab;
    int n, num;
    char *NAME;
 
    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);
    }
 
    return 0; 
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru