Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
0 / 0 / 0
Регистрация: 17.12.2012
Сообщений: 31

Хеш таблица. Метод цепочек

15.05.2015, 16:19. Показов 1921. Ответов 0
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго дня всем!
Задание такое - создать хеш таблицу. Хеширование открытое. Как я понял, надо использовать метод цепочек. А как его использовать - не придумать. Пока что всё выглядит так:

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
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
#include<iostream>
#include<string>
 
using namespace std;
 
 
class HashEl //Элемент таблицы
{
public:
    string PassNum;
    string PoB;//place of birth
    string PoI;//place of issue
    string DoI;//date of issue
    string FIO;
    string DoB;//date of birth
    bool EmptyEl;
    HashEl(string Pass_Num = "",string P_o_B = "", string P_o_I = "", string D_o_I = "", string F_I_O = "", string D_o_B = "", bool emp_el = 0)
    {
        PassNum = Pass_Num;
        PoB = P_o_B;
        PoI = P_o_I;
        DoI = D_o_I;
        FIO = F_I_O;
        DoB = D_o_B;
        EmptyEl = emp_el;
    }
    ~HashEl(){};
};
 
class HashTable
{
private:
    static const int HASH_SIZE = 20;
    HashEl *hash_table[HASH_SIZE];
    bool Empty;
public:
    HashTable()
    {
        for (int i = 0; i < HASH_SIZE; i++)
            hash_table[i] = NULL;
        Empty = NULL;
    }
    ~HashTable() { delete[] *hash_table; }
    unsigned int HashLy(string str)//хеш функция
    {
        unsigned int hash = 0;
        for(int i = 0; i<str.length(); i++)
            hash = (hash * 1664525) + (unsigned char)(str[i]) + 1013904223;
        return hash;
    }
    bool Add(HashEl *&El)
    {
        int i = 0, ind;
        int index = ind = HashLy(El->PassNum) % HASH_SIZE;
        while ((index != ind) || (i <= 1))
        {
            index = (HashLy(El->PassNum)) % HASH_SIZE;
            if ((*(hash_table + index)) != NULL && hash_table[index]->PassNum == El->PassNum)
            {
                cout << "Такой элемент уже существует!\n";
                return false;
            }
            if ((*(hash_table + index)) == NULL || (*(hash_table + index) && hash_table[index]->PassNum == "del"))
            {
                delete hash_table[index];
                hash_table[index] = El;
                Empty = false;
                return true;
            }
            else { i++; }
        }
        if (i>0 && ind == index) 
        {
            cout << "Невозможно добавить элемент!\n"; return false;
        }
        cout << "Данные сохранены!\n";
    }
    bool EmptyTab()
        {
                if (Empty == true) { return true; }
                else
                {
                        for (int i = 0; i < HASH_SIZE; i++)
                        {
                            if (hash_table[i] == NULL || hash_table[i]->PassNum =="del") { continue; }
                                else { return Empty=false; }
                        }
                        Empty = true;
                        return true;
                }
        }
    bool Show()
        {
                if (this->EmptyTab()) { cout << "Нечего отображать.\n"; system("pause"); return false; }
                else
                {
                        int i = 0;
                        int j = 0;
                        while (i < HASH_SIZE)
                        {
                                system("cls");
                                j = 0;
                                while (j < 25 && i < HASH_SIZE)
                                {
                                    if ((hash_table[i] != NULL) && (hash_table[i]->PassNum != "del"))
                                        {
                                            cout << "Номер паспорта: " << hash_table[i]->PassNum << " ФИО: " << hash_table[i]->FIO << endl;
                                            j++;
                                        }
                                        i++;
                                }
                        }
                        return true;
                }
        }
    HashEl *Search(string PassNum)
    {
        int i = 0, ind;
        int index = ind = HashLy(PassNum) % HASH_SIZE;
        while ((index != ind) || (i <= 1))
        {
            index = HashLy(PassNum) % HASH_SIZE;
            if (*(hash_table + index) != NULL)
            {
                if (hash_table[index]->PassNum == PassNum)
                {
                    cout << "ФИО пассажира: " << hash_table[index]->FIO << "\nМесто выдачи: " << hash_table[index]->PoI << "\nДата выдачи: " << hash_table[index]->DoI << "\nГод рождения: " << hash_table[index]->DoB << "\nМесто рождения: " << hash_table[index]->PoB << endl; 
                    system("pause");
                    return hash_table[index];
                }
                else if ((hash_table[index]->PassNum == PassNum) || (hash_table[index]->PassNum == "del"))
                {
                    i++;
                    continue;
                }
            }
            else { std::cout << "Такого элемента нет!\n"; return NULL; }
        }
        if (i > 0 && ind == index) { std::cout << "Такого элемента нет!\n"; return NULL; }
    }
    bool DelEl(HashEl *&El)
    {
        int i = 0, ind;
        int index = ind = HashLy(El->PassNum) % HASH_SIZE;
        while ((index != ind) || (i <= 1))
        {
            index = HashLy(El->PassNum) % HASH_SIZE;
            if (*(hash_table + index) != NULL)
            {
                if (hash_table[index]->PassNum == El->PassNum)
                {
                    hash_table[index]->PassNum = "del";
                    return true;
                }
                else if ((hash_table[index]->PassNum == El->PassNum) || (hash_table[index]->PassNum == "del"))
                {
                    i++;
                    continue;
                }
            }
            else { std::cout << "Такого элемента нет!\n"; return false; }
        }
        if (i>0 && ind == index) { std::cout << "Такого элемента нет!\n"; return false; }
    }
    //
};
Как сюда... вставить метод цепочек?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
15.05.2015, 16:19
Ответы с готовыми решениями:

Хеш-таблица (метод цепочек)
Дано: файл на 1ккк больших чисел. Задача: 1. Построить хеш-таблицу любым методом. 2. Обчислить количество возможных разных значений...

Хеш таблица с функцией (метод цепочек)
1) Не смотрите на хеш функцию, она наитупейшая, я еще над ней не работал. 2)Метод цепочек заключается в том, если в ячейке массива есть...

Хеш-таблица методом цепочек
Дано: Хеш-таблица размером 9, хеш-функция: h(k)=k mod 9. Как будет выглядеть хеш-таблица с цепочками после того, как в нее...

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
15.05.2015, 16:19
Помогаю со студенческими работами здесь

Хэш-таблица (метод цепочек)
Пишу частотный словарь текста: Массив списков узлов. В узле значение и частота слова. При написании функции void add столкнулся с...

Хэш-таблица. Метод цепочек. C++
Уважаемые, программисты, задание звучит так: &quot;Таблица строится по методу цепочек с использованием хеш-функции, возвращающей сумму двух...

Хэш - таблица методом цепочек
Всем привет! Есть задание реализовать хеш-таблицу методом цепочек + с хэш - функциями: деление и умножение. Я не до конца понимаю, что...

Хэширование метод цепочек
Помогите пожалуйста с заданием, даже не знаю с чего тут начать. Построить хеш - таблицу, содержащую последовательность из m = 53...

хеш-таблица
как в хеш таблице на си/си++ мне указать таблицу сегментов?(массив содержащий коды) typedef struct spis { int val; spis...


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Символьное дифференцирование
igorrr37 13.02.2026
/ * Программа принимает математическое выражение в виде строки и выдаёт его производную в виде строки и вычисляет значение производной при заданном х Логарифм записывается как: (x-2)log(x^2+2) -. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru