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

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

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ вычисления таблицы значений суммы S(x) http://www.cyberforum.ru/cpp-beginners/thread1024231.html
Еще раз нужно помощь высококвалифицированных специалистов! :) Проверьте мою программу, правильно ли он написан. Составить программу вычисления таблицы значений суммы S(x): S(x)=\sum_{k=1}^{n}\frac{\cos (kx)}{k} #include<iostream> #include<cmath> #define n 10 using namespace std; int main()
C++ перегрузка постфиксной и префиксной формы оператора ++ доброго времени суток форумчане, у меня такой вопрос, как перегрузить оператор ++ все другие операторы уже перегрузил осталась проблема только с этими двумя=( пишу CMyTime const operator ++(CMyTime& time); слово operator подчеркивает красным и все, не могу понять в чем дело такой метод перегрузки был описан на хабре, но он не работает у меня почему то. http://www.cyberforum.ru/cpp-beginners/thread1024216.html
C++ очень очень странная ошибка
вообщем стоит Windows 8.1 стоит visual studio 2008 возникла проблема: когда пытаюсь скомпилировать прогу - возникает 1 ошибка: 1>Проект : error PRJ0002 : Результат ошибки 2 возвращен из "C:\Program Files (x86)\Microsoft Visual Studio 9.0\VC\bin\rc.exe". в чём проблема?(( вот если что файл BuildLog.htm Журнал построения Построение начат: проект: курсач, .Конфигурация: Debug|Win32
Удаление всех элементов из динамической очереди C++
Покажите пожалуйста пример удаления.
C++ Работа с текстовыми файлами http://www.cyberforum.ru/cpp-beginners/thread1024203.html
Есть готовая программа, но надо переделать, что бы в 4 case вместо сортировки, можно было найти студента, у которого имя и фамилия (из списка) совпадает с теми, что ввел пользователь. Исходный файл что то вроде такого. заранее спасибо!) 0 Uwe Boll 32 12 44 1 Valentin Strikalo 22 03 92 2 Eugene Belnikov 12 8 66 3 Ratibor Berestov 06 02 67 4 Peter Sundae 22 04 55 5 Janis Licis 13...
C++ Как реализовать алгоритм Шимбелла? помогите создать алгоритм Шимбелла вот мои наброски #include<iostream> #include<string> #include<cstdio> #include<cstdlib> #define word unsigned int using namespace std; подробнее

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

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

01.12.2013, 10:40. Просмотров 419. Ответов 0
Метки (Все метки)

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

Добавлено через 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;
}
Что не так?????
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru