Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
0 / 0 / 0
Регистрация: 16.11.2013
Сообщений: 5

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

01.12.2013, 10:40. Показов 5149. Ответов 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;
}
Что не так?????
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
01.12.2013, 10:40
Ответы с готовыми решениями:

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

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

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

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
01.12.2013, 10:40
Помогаю со студенческими работами здесь

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

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

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

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

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


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
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
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru