Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 5.00/9: Рейтинг темы: голосов - 9, средняя оценка - 5.00
5 / 5 / 1
Регистрация: 23.02.2013
Сообщений: 71

У меня было задание создать класс для хэширования в строку

24.04.2013, 22:12. Показов 1897. Ответов 23
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
вот моя реализация:
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
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Collections;
 
namespace lab3
{
    class StringHashTable
    {
        private int _count;
        private const int _hashModulo = 1000;
        private List< Tuple <string, string> >[] _table;
 
        public int Count
        {
            get
            {
                return _count;
            }
        }
 
 
        public StringHashTable()
        {
            _count = 0;
            _table = new List< Tuple<string, string> >[_hashModulo];
 
            for (int i = 0; i < _hashModulo; i++)
            {
                _table[i] = new List<Tuple<string,string>>();
            }
        }
 
        public void Add(string key, string value)
        {
            if (Contains(key))
            {
                return;
            }
            int hash = GetHash(key);
            _table[hash].Add(new Tuple<string, string>(key, value));
            _count++;            
        }
 
        public bool Contains(string key)
        {
            int hash = GetHash(key);
            return -1 != _table[hash].FindIndex(x => x.Item1 == key);
        }
 
        public string FindByKey(string key)
        {
            int hash = GetHash(key);
 
            foreach (var item in _table[hash])
            {
                if (item.Item1 == key)
                {
                    return item.Item2;
                }
            }
 
            return null;
        }
 
        public void Remove(string str)
        {
            int hash = GetHash(str);
 
            int index = _table[hash].FindIndex(x => x.Item1 == str);
 
            if (index != -1)
            {
                _table[hash].RemoveAt(index);
                _count--;
            }            
        }
 
        private int GetHash(string str)
        {
            return Math.Abs(str.GetHashCode() % _hashModulo);
        }
 
        public Tuple<string, string>[] ToArray()
        {
            Tuple<string, string>[] arr = new Tuple<string, string>[_count];
 
            int curr = 0;
 
            foreach (var bucket in _table)
            {
                foreach (var item in bucket)
                {
                    arr[curr++] = item;
                }
            }
 
            return arr;
        }
    }
}
Ходил сдавать его, мне сказали, нельзя использовать стандартную функцию List
Помогите решить этот вопрос
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
24.04.2013, 22:12
Ответы с готовыми решениями:

Класс для представления хэширования в строку
Покажите, как правильно реализовать

Как создать связь, чтоб меня нельзя было вычислить?
Допустим у меня номер X. Мне звонят с номера Y(или может я звоню на Y). Беседа длится какое-то время T. Мне нужно, чтобы ни во время...

Реализовать класс Triangle (задание 25), опираясь на класс Angle из задания 26 для представления углов
Реализовать класс Triangle (задание 25), опираясь на класс Angle из задания 26 для представления углов. Собственно вот такая проблема. Не...

23
 Аватар для n1l
136 / 138 / 18
Регистрация: 26.07.2010
Сообщений: 911
25.04.2013, 06:47
C#
1
str.GetHashCode()
Я думаю вот эту стандартную функцию имели ввиду.
По какому алгоритму вас заставили делать хеш?
1
5 / 5 / 1
Регистрация: 23.02.2013
Сообщений: 71
25.04.2013, 09:45  [ТС]
Функцию Gethesh я не использовал. Мне сказали, нужно сделать все без List
0
 Аватар для n1l
136 / 138 / 18
Регистрация: 26.07.2010
Сообщений: 911
25.04.2013, 09:51
Я понять не могу, вы хотите захешировать строку или создать хештаблицу?
1
5 / 5 / 1
Регистрация: 23.02.2013
Сообщений: 71
25.04.2013, 09:54  [ТС]
Именно+ должны быть методы поиска по ключу, по значению, удаления по ключу и значению
Это к меня все уже реализована, но мне сказали, что нельзя использовать Листы
0
 Аватар для n1l
136 / 138 / 18
Регистрация: 26.07.2010
Сообщений: 911
25.04.2013, 10:45
Ну во первых создание хештаблицы и хеширование - вещи абсолютно разные!
Во вторых прочтите определение хештаблицы, ибо у вас там в принципе еще вообще ничего не сделано.

вики

1) Алгоритм хеширования для получения ключа.
2) Если нельзя пользоваться стандартными коллекциями, то вам придется реализовать сначала коллекцию связанного списка.
3) Далее создать элемент хештаблицы, состоящий из ключа и связанного списка.

Для удобства еще можно реализовать IEnumerable<T>
1
5 / 5 / 1
Регистрация: 23.02.2013
Сообщений: 71
25.04.2013, 11:03  [ТС]
Не могли бы вы мне помочь с этим связным списком?
0
 Аватар для n1l
136 / 138 / 18
Регистрация: 26.07.2010
Сообщений: 911
25.04.2013, 12:23
Что-то типа этого... Накидал за 15 минут.

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
public class LinkedList<T>: IEnumerable<T>
    {
 
        private Element _root;
        private Element _current;
 
        public class Element
        {
            public T Value { get; set; }
            public Element Next { get; set; }
 
            public Element(T value, Element next)
            {
                Value = value;
                Next = next;
            }
        }
        public LinkedList(List<T> list)
        {
            Element result = null;
            Element current = null;
 
            foreach (var item in list)
            {
                var element = new Element(item, null);
                if (current == null)
                {
                    current = element;
                    result = current;
                }
                else
                {
                    current.Next = element;
                    current = current.Next;
                }
            }
            _root = result;
        }
 
        #region IEnumerable<T> Members
 
        public IEnumerator<T> GetEnumerator()
        {
            while(_root!=null)
            {
                _current = _root;
                _root = _root.Next;
                yield return _current.Value;
            }
        }
 
        #endregion
 
        #region IEnumerable Members
 
        System.Collections.IEnumerator System.Collections.IEnumerable.GetEnumerator()
        {
            return GetEnumerator();
        }
 
        #endregion
    }
Добавлено через 2 минуты
Использовать можно вот так.

C#
1
2
3
4
5
6
7
8
9
static void Main(string[] args)
        {
            var list = new LinkedList<string>(new List<string>{"abc", "asd", "123", "klo"});
 
            foreach (var item in list)
            {
                Console.WriteLine(item);
            }
        }
Тут нет метода добавления, метода reverse тоже и еще кучи всего нужного, если уж совсем тяжко будет, я после работы подробнее покажу.
После университета совсем уже забыл все, никак не могу вспомнить, извините.
1
5 / 5 / 1
Регистрация: 23.02.2013
Сообщений: 71
25.04.2013, 17:21  [ТС]
можете по-подробнее, если не затруднит
0
 Аватар для n1l
136 / 138 / 18
Регистрация: 26.07.2010
Сообщений: 911
26.04.2013, 12:16
Цитата Сообщение от Sevi4_by Посмотреть сообщение
можете по-подробнее, если не затруднит
До субботы не смогу, к сожалению.
1
5 / 5 / 1
Регистрация: 23.02.2013
Сообщений: 71
26.04.2013, 17:02  [ТС]
я подожду, без проблем
0
5 / 5 / 1
Регистрация: 23.02.2013
Сообщений: 71
28.04.2013, 00:34  [ТС]
я подожду, без проблем

Добавлено через 1 минуту
я подожду)
0
Master of Orion
Эксперт .NET
 Аватар для Psilon
6101 / 4957 / 905
Регистрация: 10.07.2011
Сообщений: 14,522
Записей в блоге: 5
28.04.2013, 08:11
Sevi4_by, вы список чтоль не можете реализовать? Так вам же все расписали, можете разве что теорию почитать. Есть указатель на голову и хвост, есть операция добавления и удаления... В общем, все довольно просто

Добавлено через 1 минуту
Если не знаете, как реализовывать, наследуйте от интерфейса ICollection, он вам все подскажет и пнет, какие методы нужно добавить

Добавлено через 22 минуты
Вот набросал примерчик:
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
using System;
using System.Collections;
using System.Collections.Generic;
using System.Linq;
 
namespace ConsoleApplication34
{
    public class MyLinkedList<T> : ICollection<T>
    {
        private class Element
        {
            public Element(T data)
            {
                Data = data;
                Next = null;
            }
 
            public T Data { get; set; }
            public Element Next { get; set; }
        }
 
        private class DefaultComparer : IEqualityComparer<T>
        {
            public bool Equals(T x, T y)
            {
                return x.Equals(y);
            }
 
            public int GetHashCode(T obj)
            {
                return obj.GetHashCode();
            }
        }
 
        private Element head, tail;
        private readonly IEqualityComparer<T> comparer;
 
        public MyLinkedList(IEqualityComparer<T> comparer, bool isReadOnly)
        {
            Count = 0;
            this.comparer = comparer;
            IsReadOnly = isReadOnly;
        }
 
        public MyLinkedList(bool isReadOnly)
            : this(new DefaultComparer(), isReadOnly)
        {
        }
 
        public MyLinkedList(IEqualityComparer<T> comparer)
            : this(comparer, false)
        {
        }
 
        public MyLinkedList()
            : this(new DefaultComparer(), false)
        {
        }
 
        public IEnumerator<T> GetEnumerator()
        {
            for (Element element = head; element != null; element = element.Next)
                yield return element.Data;
        }
 
        IEnumerator IEnumerable.GetEnumerator()
        {
            return GetEnumerator();
        }
 
        public void Add(T item)
        {
            var elm = new Element(item);
            if (head == null)
                head = tail = elm;
            else
            {
                tail.Next = elm;
                tail = elm;
            }
            Count++;
        }
 
        public void Clear()
        {
            Count = 0;
            head = tail = null;
        }
 
        public bool Contains(T item)
        {
            return GetElement(item) != null;
        }
 
        private Element GetElement(T item)
        {
            for (Element element = head; element != null; element = element.Next)
                if (comparer.Equals(item, element.Data))
                    return element;
            return null;
        }
 
        public void CopyTo(T[] array, int arrayIndex)
        {
            Array.Copy(this.ToArray(), 0, array, arrayIndex, Count);
        }
 
        public bool Remove(T item)
        {
            if (IsReadOnly)
                throw new NotSupportedException();
            Element element;
            for (element = head;
                 element.Next != null && !comparer.Equals(item, element.Next.Data);
                 element = element.Next)
            {
            }
            if (element.Next == null)
                return false;
            element.Next = element.Next.Next;
            Count--;
            return true;
        }
 
        public int Count { get; private set; }
        public bool IsReadOnly { get; private set; }
    }
 
    public class Program
    {
        private static void Main()
        {
            var list = new MyLinkedList<int>();
            for (int i = 0; i < 5; i++)
            {
                list.Add(i);
            }
            foreach (int i in list)
                Console.Write(i + " ");
            list.Remove(4);
            Console.WriteLine();
            foreach (int i in list)
                Console.Write(i + " ");
            list.Clear();
            Console.ReadKey();
        }
    }
}
Добавлено через 7 минут
n1l, а у вас кстати после первой же итерации по итератору root попадет в null и коллекция опустошится
0
 Аватар для n1l
136 / 138 / 18
Регистрация: 26.07.2010
Сообщений: 911
28.04.2013, 09:01
Цитата Сообщение от Psilon Посмотреть сообщение
Добавлено через 7 минут
n1l, а у вас кстати после первой же итерации по итератору root попадет в null и коллекция опустошится
Спасибо капитан. Думаете я не знаю? И не после итерации, а после первого прохода списка, о чем я и указал в виде комментария -
Цитата Сообщение от n1l Посмотреть сообщение
Тут нет метода добавления, метода reverse и еще кучи всего нужного
0
Master of Orion
Эксперт .NET
 Аватар для Psilon
6101 / 4957 / 905
Регистрация: 10.07.2011
Сообщений: 14,522
Записей в блоге: 5
28.04.2013, 09:04
Цитата Сообщение от n1l Посмотреть сообщение
Спасибо капитан.
всегда пожалуйста
Думаете я не знаю?
видимо, нет.
И не после итерации, а после первого прохода списка, о чем я и указал в виде комментария -
Поясните разницу между прохождением списка и итерации итератора, а то я что-то не уловил.

алсо отсутствие метода добавления != опустошение списка после итерации.
0
 Аватар для n1l
136 / 138 / 18
Регистрация: 26.07.2010
Сообщений: 911
28.04.2013, 09:08
Цитата Сообщение от Psilon Посмотреть сообщение
всегда пожалуйста

видимо, нет.

Поясните разницу между прохождением списка и итерации итератора, а то я что-то не уловил.

алсо отсутствие метода добавления != опустошение списка после итерации.
Какого метода добавления? Вы только первые два слова в комментариях читаете?
Итерация - одно полное выполнение действий в цикле.
Полное прохождение - полное прохождение цикла, выполнение всех итераций.
0
Master of Orion
Эксперт .NET
 Аватар для Psilon
6101 / 4957 / 905
Регистрация: 10.07.2011
Сообщений: 14,522
Записей в блоге: 5
28.04.2013, 09:11
n1l, итерация итератора - полное выполнение процедуры foreach
в чем же отличие от "Полного прохождения" я так и не понял...
0
 Аватар для n1l
136 / 138 / 18
Регистрация: 26.07.2010
Сообщений: 911
28.04.2013, 09:21
Цитата Сообщение от Psilon Посмотреть сообщение
n1l, итерация итератора - полное выполнение процедуры foreach
в чем же отличие от "Полного прохождения" я так и не понял...
Облажался и облажался, так и скажи, вот чего юлить то?
Каждый студент знает что такое итерация, господи, и это не полное выполнение цикла, а один его полный проход.
Читать до полного просветления если что-то непонятно, я вам ничего объяснять не должен, мне это не нужно итерация

Считаете в моем коде что-то выполнено не правильно, можете исправлять хоть до посинения, избавите меня от дополнительных обязательств.
1
Master of Orion
Эксперт .NET
 Аватар для Psilon
6101 / 4957 / 905
Регистрация: 10.07.2011
Сообщений: 14,522
Записей в блоге: 5
28.04.2013, 09:51
n1l, ок, с итерацией лажанул (сам не знаю почему, видимо, 4 часа на сон - мало). В остальном то я прав
0
 Аватар для n1l
136 / 138 / 18
Регистрация: 26.07.2010
Сообщений: 911
28.04.2013, 11:56
Цитата Сообщение от Psilon Посмотреть сообщение
n1l, ок, с итерацией лажанул (сам не знаю почему, видимо, 4 часа на сон - мало). В остальном то я прав
В чем в остальном, в том что я не доделал коллекцию полностью?
Да, я об этом уже сообщил.
Ну нет у меня времени на работе создавать полностью рабочую оттестированную коллекцию связанного списка, со всеми методами и ошибками которые там могут быть.
Если бы я следовал вашей философии, то я тут должен составить список методов которых не хватает у вас, например проверка на зацикленность, переворот списка без изменения оригинала и с изменением оригинала.
Все люди которые тут обитают дают примеры, просто примеры.
Это не идеально и полностью законченные куски кода, а всего лишь примеры.

Добавлено через 36 секунд
PS
Извините накипело, так как вы не один такой "точный".
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
28.04.2013, 11:56
Помогаю со студенческими работами здесь

8 Класс, все просто но не для меня!
Решите вторую и третью задачи (Файл во вложениии!). Я Вас очень прошу, пожалуйста!!!)))

Создать класс Mystring, предназначенный для хранения строки из символов типа char. Класс имеет метод для определения дли
Создать класс Mystring, предназначенный для хранения строки из символов типа char. Класс имеет метод для определения длины строки. Не...

Определить класс-строку. В класс включить два конструктора: для определения класса строки строкой символов и п
Определить класс-строку. В класс включить два конструктора: для определения класса строки строкой символов и путем копирования другой...

Определить класс-строку. В класс включить два конструктора: для определения класса строки строкой символов и путем копир
Всем привет, помогите пожалуйста, я уже всю голову сломал, не знаю как решить ее... Определить класс-строку. В класс включить два...

Создать класс строку в С++. Переопределение операторов
Доброго времени суток. Подскажите пожалуйста в чём ошибка в операторе &gt;&gt;. Когда его вызываю в основной программе, то почему-то компилятор...


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

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru