С Новым годом! Форум программистов, компьютерный форум, киберфорум
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
hektor
0 / 0 / 0
Регистрация: 14.10.2010
Сообщений: 15
#1

итератор для хеш таблицы - C++

09.11.2011, 11:12. Просмотров 1033. Ответов 0
Метки нет (Все метки)

Код
//Hash Table String
#include <iostream>
#include <string>
#include <vector>
//#include <TestFramework.h>
using namespace std;
const int size = 256;
template <typename V>
class HashTable 
{
	//array of pairs(keys,value)
	vector<vector<pair<string,V>>> table;
	//count
	int count;
public:
	//constructor
	HashTable ()
	{
		table.resize(size);
		count = 0;
	}
	//destructor
	~HashTable ()
	{
		table.clear();
	}
	//hash function
	int hashF (string key) 
	{
		const int p = 31;
		long long hash = 0, p_pow = 1;
		int n = key.length();
		for (int i = 0; i < n; ++i)
		{
			hash += key[i] * p_pow;
			p_pow *= p;
		}
		return hash%size;
	}
	//adding a new pair
	V & operator [] (string index)
	{
		pair<string,V> check;
		int hash = 0;
		hash = hashF (index);
		vector<pair<string,V>>::iterator it;
		check.first = index;
		table[hash].push_back(check);
		it = table[hash].end();
		it--;
		count++;
		return (*it).second;
	}
	//search pair function
	V get (string index)
	{
		int hash = hashF (index);
		vector<pair<string,V>>::iterator it;
		it = table[hash].begin();
		while (it->first != index)
		{
			it++;
		}
		return (*it).second;
	}
	//delete pair function
	void del (string index)
	{
		int hash = hashF (index),k = 0; 
		vector<pair<string,V>>::iterator it = table[hash].begin();
		while (it->first != index)
		{
			it++;
			k++;
		}
		table[hash].erase(table[hash].begin()+k);
		count--;
	}
	int getCount ()
	{
		return count;
	}
	int* getIndex ()
	{
		return index;
	}
	vector<vector<pair<string,V>>> getTable()
	{
		return table;
	}
};
template <typename V>

class Iterator 
{
	typename vector<vector<pair<string,V>>>::iterator it1;		//итератор для перемещения по хеш таблицы
	typename vector<pair<string,V>>::iterator it2;		//итератор для перемещения по корзине
	typename vector<vector<pair<string,V>>> basket;		//корзина
	int right; //индекс для непустой корзины, с каждым вызовом оператора + + должно искать следующую ненулевую корзину
	int index; //индекс перемещения по корзине
public:
	Iterator(HashTable<V> ob)
	{
		basket = ob.getTable();
		right = -1;
		index = 0;
	}
	int rightNotZero (int right, vector<vector<pair<string,V>>> basket)
	{
		for (int i = right+1; i < size; i++)
		{
			if (basket[i].empty() == 0)
			{
				right = i;//от тут все нормально right = i;
				break;
			}
		}
		return right;
	}
public:
	Iterator & operator++ ()
	{  
		int n = rightNotZero(right,basket);    //вот тут проблема при первом и последующих вызовах right остается -1,
												//а надо чтобы менялось при вызове функции rightNotZero
		it2 = basket[n].begin();
		advance(it2,index);
		if (it2 == basket[n].end())
		{
			n = rightNotZero (right,basket);
			it2 = basket[n].begin();
			index = 1;
		}
		else
		{
			index++;
		}
		return *this;
	}
	V & operator* ()
	{
		return (*it2).second;
	}
};
int main ()
{
	HashTable<int>ob;
	ob["a"]=2;
	ob["b"]=3;
	ob["c"]=4;
	Iterator<int> it(ob);
	++it;
	++it;
	cout << *it << endl; //должно равняться 3 а не 2
	return 0;
}
смотрите на класс итератор, я в комментариях описал проблему

Добавлено через 9 часов 46 минут
спасибо уже разобрался, мне надо было функцию rightNotZero() написать так:
C++
1
2
3
4
5
6
7
8
9
10
11
    void rightNotZero ()
    {
        for (int i = right+1; i < size; i++)
        {
            if (basket[i].empty() == 0)
            {
                right = i;
                break;
            }
        }
    }
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
09.11.2011, 11:12
Здравствуйте! Я подобрал для вас темы с ответами на вопрос итератор для хеш таблицы (C++):

для чего нужны хеш таблицы? - C++
для чего нужны хеш таблицы? если есть массивы )

Реализовать двусвязный список (list), итератор (iterator) и константный итератор (сonst_iterator) для списка - C++
не могу понять что должно быть результатом. может подскажете примеры? пожалуйста. Задание: Реализовать двусвязный список (list),...

Хеш таблицы - C++
Начал изучать хеш таблицы. Подскажите насчёт хеш таблиц с открытимы адрессами: - Должны ли мы инициализировать значение ключа...

хеш-таблицы - C++
Реализовать ассоциативный массив в виде хеш-таблицы с операциями добавления, поиска . Ключом массива должна быть строка, значением – целое...

Реализация хеш-таблицы - C++
Всем привет. Нужна помощь с заданием:

Не могу найти ошибку. Хеш-таблицы - C++
Программа работает, в принципе, правильно, но есть маленькие погрешности при поиске элементов. То есть мы точно знаем, что элемент такой...

0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
09.11.2011, 11:12
Привет! Вот еще темы с ответами:

Уменьшить число коллизий хеш-таблицы - C++
Задание: хеш-таблица с мультипликативной хеширующей функцией (метод умножения) и решением коллизий внутренними (срастающимися) цепочками. ...

Хеш-таблицы: string subscript out of range - C++
#include &lt;iostream&gt; #include &lt;string.h&gt; #include &lt;string&gt; using namespace std; typedef string nametype; struct celltype { ...

Данные о читателях должны быть организованны в виде хеш-таблицы - C++
Данные о каждом читателе должны содержать: № читательского билета – строка формата «ANNNN-YY», где A – буква, обозначающая права доступа...

Хеш-таблицы, сгенерировать список различных слов в тексте (с количеством вхождений их в этот текст) - C++
Напишите компьютерную программу которая использует хеширование для следующей задачи. Имеется текст на естественном языке. Требует- ся...


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

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

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