Форум программистов, компьютерный форум, киберфорум
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Жасулан
1 / 1 / 0
Регистрация: 22.10.2013
Сообщений: 68
#1

Ошибка вычислений или переполнение (протокол Диффи-Хеллмана) - C++

13.12.2013, 07:20. Просмотров 444. Ответов 4
Метки нет (Все метки)

привет всем!! я реализовал протокол диффи хеллмана, но он работеат только с маленькими числами,что нужно изменить чтоб он работал с прилично большими числами? если ввести 23 и 7, 3 и 6 то все нормально,но даже при 97 и 5, 36 и 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
37
38
39
40
41
42
43
44
45
46
47
48
using namespace std;
#include<conio.h>
#include<iostream>
#include<math.h>
 
int alice(int,int,int);
int bob(int,int,int);
void main()
{
    setlocale(0,"");    
    long double g,x,y,a,b,k1,k2,n;
 
 cout<<"\n\t n мен g-енгиз ";
 cin>>n>>g;
 
 cout<<"\n\t x пен y енгиз ";
 cin>>x>>y;
 
 a=alice(n,g,x);
 cout<<"\n\t alice ашык килти: "<<a;
 
 b=bob(n,g,y);
 cout<<"\n\t bob ашык килти: "<<b;
 
 k1=alice(n,b,x);
 cout<<"\n\t алисанын жасырын килти: "<<k1;
 
 k2=alice(n,a,y);
 cout<<"\n\t бобтын жасырын килти :"<<k2;
 
 getch();
}
 
int alice(int n,int g,int x)
{
 long int a,a1;
 a1 = static_cast<long double>(pow(static_cast<double>(g), x));
 a=a1%  n;
 return(a);
}
 
int bob(int n,int g,int y)
{
 long int b,b1,k2,t2;
 b1 = static_cast<long double>(pow(static_cast<double>(g), y));
 b=b1%n;
 return(b);
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
13.12.2013, 07:20
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Ошибка вычислений или переполнение (протокол Диффи-Хеллмана) (C++):

Алгоритм Диффи-Хеллмана. Ошибка вычисления - C++
Добрый вечер, я реализую алгоритм Диффи-Хелмана и столкнулся со следующими проблемами 1) в программе неправильно вычисляется значение k2...

Запустить исходник Диффи-Хеллмана - C++
вот код реализации диффи хеллмана,но я не могу запустить ее: помогите разобратся)) /* * dh.c * Example source file for D-H algorithm...

Алгоритм Диффи-Хеллмана на эллиптических кривых - C++
Здравствуйте , не поможете разобраться с алгоритмом Диффи-Хелмана на эллиптических кривых? Я видимо не совсем правильно понимаю работу...

Переполнение потока или же что-то иное - C++
В общем создал функцию, которая будет запрашивать пользователя вводить строку, пока она не будет меньше чем 25 символов: void...

Ошибка этапа исполнения - переполнение стека - C++
Помогите пожалуйста C++ написала программу она правильно работает, но при каждом запуске она выкидывает окно переполнение стека...

Протокол Диффи-Хеллмана - C#
Решил реализовать передачу ключа по протоколу ДХ, вот исходник: static void Main(string args) { ...

4
Ryuk
179 / 177 / 33
Регистрация: 10.06.2011
Сообщений: 871
13.12.2013, 07:25 #2
Жасулан, укажите типы unsigned long long.
0
Жасулан
1 / 1 / 0
Регистрация: 22.10.2013
Сообщений: 68
13.12.2013, 07:27  [ТС] #3
Ryuk, вместо long double?
0
Ryuk
179 / 177 / 33
Регистрация: 10.06.2011
Сообщений: 871
13.12.2013, 07:29 #4
Жасулан, я не смотрел вашу задачу, я бегло глянул код. Смотря что и с чем у вас работает. Если не поможет, будем разбираться.
0
Жасулан
1 / 1 / 0
Регистрация: 22.10.2013
Сообщений: 68
13.12.2013, 10:16  [ТС] #5
Ryuk, замена типа не помогла,не могу пончть в чем проблема
0
13.12.2013, 10:16
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
13.12.2013, 10:16
Привет! Вот еще темы с ответами:

Алгоритм Диффи-Хеллмана - Perl
необходимо реализовать алгоритм Диффи-Хеллмана на перл

Группы Диффи-Хеллмана - Криптография
Добрый день! Встретил такую формулировку &quot;Diffie-Hellman groups&quot; или еще такую &quot;DH with negotiated groups&quot;, попытался по этим ключевым...

Простейший алгоритм Диффи-Хеллмана - JavaScript
Пробую совсем просто, без заморочек, написать алгоритм ДХ, но в результате ключи почему-то разные... Подскажите, может я где-то ошибся... ...

Алгоритм Диффи — Хеллмана програмная реализацыя - C#
(Прошу прощения за корявый русский) помогите з реализацией етого алгоритма) По заданию уменя есть g(в степени)а mod p (). а и g могут...


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

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

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru