Форум программистов, компьютерный форум, киберфорум
C++
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.67/6: Рейтинг темы: голосов - 6, средняя оценка - 4.67
0 / 0 / 1
Регистрация: 18.04.2010
Сообщений: 19
1

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

16.12.2010, 18:47. Просмотров 1241. Ответов 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; 
}
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
16.12.2010, 18:47
Ответы с готовыми решениями:

Заменить контейнер vector, использовавшийся для хранения текстовых строк (листинг 2.3), на контейнер list
Здравствуйте форумчане, может кто объяснить как делать это задание и что собственно мы тут вообще...

Подскажите контейнер для хранения данных
Доброе время суток, имеем файл следующего содержания: # | Name | Type | Target 1 test txt ...

Контейнер для хранения информации
создал CLR/C++, добавил winforms, разместил пару textbox, разместил кнопку. создал класс и...

Подскажите контейнер для хранения
Задача такая, нужно хранить уникальные строки например в Set&lt;&gt; но при этом мне надо одновременно...

2
3050 / 1455 / 492
Регистрация: 29.11.2010
Сообщений: 2,888
16.12.2010, 22:55 2
Есть подозрение, что это двусвязный список.
0
0 / 0 / 1
Регистрация: 18.04.2010
Сообщений: 19
16.12.2010, 23:03  [ТС] 3
Цитата Сообщение от 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
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
16.12.2010, 23:03

Заказываю контрольные, курсовые, дипломные и любые другие студенческие работы здесь.

Класс-контейнер для хранения различных типов
Здравствуйте, товарищи!!! Подскажите, есть ли класс-контейнер для одновременного хранения в нем...

Разработать шаблон класса для хранения данных (контейнер)
Я не понял как описать шаблон класса для хранения данных (контейнер). Данные должны хранится,...

Организовать двунаправленный список для хранения элементов структуры, содержащей сведения о фамилии, дате рождения
Организовать двунаправленный список для хранения элементов структуры, содержащей сведения о...

Разработать класс Keeper, который реализует контейнер для хранения и обработки объектов
Есть задание по лабораторной работе. Нельзя использовать STL контейнеры для реализации программы....


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2020, vBulletin Solutions, Inc.