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

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

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ С++ код с использованием СОМ объектов. http://www.cyberforum.ru/cpp-beginners/thread380215.html
Пообещал другу написать прогу, кликер мыши в броузере(IE) на с++ с COM объектами. Вот код: #include <iostream> #include <stdlib.h> #include <windows.h> void main() {
C++ Работа с двухмерными массивами Привет всем. Помогите пожалуйста. Нужно в двухмерном массиве 10х10 переставить столбцы в порядке увеличения количества элеменов=0 в столбцах. Тоесть: 1 2 3 4 0 2 0 5 0 3 0 5 2 0 0 6 Конечный... http://www.cyberforum.ru/cpp-beginners/thread380205.html
C++ Сортировка двухпутевыми вставками.
У меня есть образец на паскале я его попробывал переделать на С++ но чо-то запутался ))). Массив int. Может кто-то знает как его правильно сделать ?
Массив C++
#pragma argsused #include <iostream.h> #include <conio.h> #include <stdlib.h> int main(int argc, char* argv) { int i,n,j,**a; cout <<"Vvedite razmernost' matricy ="; cin...
C++ Перевести программу с языка Паскаль в язык С++ http://www.cyberforum.ru/cpp-beginners/thread380192.html
Имееться задача на Pascale: {Метод Ньютона решения нелинейного уравнения} program Newton; uses crt; {модуль управления экраном} function f(x:real):real; {Исходная функция} begin ...
C++ Проверить, имеется ли в одномерном числовом массиве A из n элементов, хотя бы одна пара взаимно обратных чисел. Проверить, имеется ли в одномерном числовом массиве A из n элементов, хотя бы одна пара взаимно обратных чисел. перенес в С++ подробнее

Показать сообщение отдельно
hektor
0 / 0 / 0
Регистрация: 14.10.2010
Сообщений: 15

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

09.11.2011, 11:12. Просмотров 1023. Ответов 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
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru