Форум программистов, компьютерный форум CyberForum.ru

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

Восстановить пароль Регистрация
 
denis0174
0 / 0 / 0
Регистрация: 16.11.2013
Сообщений: 5
01.12.2013, 10:40     Метод хеширования – свертка с выбором цифр #1
Метод хеширования – свертка с выбором цифр С++)Нужна помощь срочно)))Ребята помогите пожалуйста

Добавлено через 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;
}
Что не так?????
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
01.12.2013, 10:40     Метод хеширования – свертка с выбором цифр
Посмотрите здесь:

C++ Метод сортировки выбором!!!
Метод сортировки выбором -2 C++
Метод Гаусса с выбором главного элемента C++
C++ Метод сортировки выбором счётчик количества итераций C++
C++ Хеш-функции. Метод открытого хеширования
C++ Метод открытого хеширования и хеш-функция, основанная на методе деления с остатком
C++ Метод Гаусса с выбором элемента по столбцу
C++ Метод сортировки прямым выбором

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Ответ Создать тему
Опции темы

Текущее время: 21:08. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru