0 / 0 / 0
Регистрация: 16.11.2013
Сообщений: 5
1

Метод хеширования – свертка с выбором цифр

01.12.2013, 10:40. Показов 4501. Ответов 0
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Метод хеширования – свертка с выбором цифр С++)Нужна помощь срочно)))Ребята помогите пожалуйста

Добавлено через 1 час 46 минут
Метод выбора цифр
Хеш-функция, основанная на выборе цифр, формирует хеш-значение, как комбинацию отдельных цифр ключа. Например, для хеш-таблицы с размером m = 1000 из 12-значного ключа 12376945012310 можно выбрать первую, шестую и двенадцатую цифры и сформировать индекс 14310 или 34110 , если выбирать цифры в обратном порядке. Для уменьшения вероятности коллизий рекомендуется также учитывать номера позиций, из которых выбираются цифры. Для этого значение выбранной цифры можно складывать с номером позиции по модулю основания системы счисления. Например для ключа 7777777777710 с учетом номеров позиций цифр получается индекс 72710 , а для ключа 7777710 - 19710 .
Запись цифр в позиционной десятичной системе и будет представлять хеш-значение, лежащее в диапазоне от 0 до 99910. Но такой способ хеширования оправдывает себя, если ключи элементов, вставляемых в таблицу, равномерно распределены на всём диапазоне значений.
Метод свёртки
Метод свёртки группирует цифры ключа и складывает группы цифр по модулю m. Например, для m = 1000 ключ 12376945012310 можно преобразовать по схеме:
(12310 + 76910 + 45010 + 12310 ) mod 1000 = 46510 .

Для уменьшения вероятности коллизий рекомендуется также учитывать номера групп, которые выбираются из ключа. Для этого значение цифр в выбранной группе можно складывать с номером группы по модулю основания системы счисления. Например, без учета номеров групп ключи 987123456 и 456987123 дадут одинаковое хеш - значение по методу свертки:
(98710 + 12310 + 45610) mod 1000 = 56610
(45610 + 98710 + 12310) mod 1000 = 56610
Если с каждой цифрой сложит номер ее позиции по модулю 10, то получатся хеш - значения:
(10910 + 23410 + 45610) mod 1000 =79910
(67810 + 09810 + 12310) mod 1000 = 89910

Можно применять свёртку, комбинированную с выбором цифр. Например, сначала выполняется простое суммирование групп цифр ключа, а из полученной суммы выбирается нужное количество цифр.




Как это реализовать на С++

Добавлено через 12 часов 58 минут
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
#include<stdio.h>
#include<conio.h>
#include<stdlib.h>
#include<math.h>
#include<windows.h>
int hash3(long key) // ìåòîä ñâåðòêè
{
    int result = 0;
    int k=1;    
        int q=0;
    while( key>0)
    {
        q=key;
        //key=key/100;
        if( key>99)
        {
        k=100;
        key=key/100;
        k=k*100;
        }
        result += key;
        key = key%k ;
    }
return  result;
}
int main()
{
    long int M;
    int j;
    puts("fff");
    scanf("%d",&M);
    j=hash3(M);
   
    printf("=%d",j);
    return 0;
}
Что не так?????
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
01.12.2013, 10:40
Ответы с готовыми решениями:

Контрольные суммы и метод хеширования
Помогите пожалуйста с заданием. Как сделать? Пусть а = 13, b = 19, с = МахVal + 1 = 256, t0 =...

Хеш-функции. Метод открытого хеширования
Написать программу, которая реализует метод открытого хеширования и хеш-функцией, основанной на...

Метод открытого хеширования и хеш-функция, основанная на методе деления с остатком
Ещё раз здравствуйте! Есть такое задание: Написать программу, которая реализует метод...

Метод закрытого хеширования с двойным хешированием и хеш-функция, основанная на методе деления с остатком
Доброго времени суток! Прошу помощи у более опытных прогорев. До этого никогда не работал с...

0
01.12.2013, 10:40
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
01.12.2013, 10:40
Помогаю со студенческими работами здесь

Метод закрытого хеширования с двойным хешированием и хеш-функция, основанная на методе деления с остатком
Доброго времени суток! Прошу помощи у более опытных прогорев. До этого никогда не работал с...

Ребят как переделать метод сортировки пузырьком на метод сортировки простым выбором
public void SortPuzirek(int mass, int Size) // метод, выполняющий сортировку методом пузырька ...

Метод сортировки выбором -2
Доброе время суток, Чтоб не засорять чужую тему с чужими задачи, решил создать новую. :) ...

Метод сортировки выбором!!!
ВАРИАНТ 21 Написать программу, которая методом сортировки выбором сортирует введенный...


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

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

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru