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

Надо сгенерировать 8-битное значение

26.11.2015, 15:53. Показов 1201. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
В моей программе мне нужно сгенерировать 8-байтовое целочисленное значение.
Я попробовал сделать так...
C++
1
unsigned long long element = (((unsigned)rand() << 32) | (unsigned)rand());
но в результате совсем не то, что я ожидал.
Как мне сгенерировать 8-байтовое значение?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
26.11.2015, 15:53
Ответы с готовыми решениями:

160 битное значение, представляющее целое число, конвертировать в string в десятичном представлении
Есть 160 битное значение представляющее целое число, необходимо конвертировать его в string в 10ом представление. Существуют реализации?...

Написать функцию, которая принимает 32 битное целое число и возвращает 16 битное целое число
Помогите написать программу, использующую функцию, которая принимает 32 битное целое число и возвращает 16 битное целое число, состоящее из...

Как сгенерировать к-битное число p
Доброй ночи!:-/ Вопрос: как сгенерировать к-битное число p на c#?

7
Почетный модератор
Эксперт С++
 Аватар для SatanaXIII
5851 / 2862 / 392
Регистрация: 01.11.2011
Сообщений: 6,906
26.11.2015, 15:58
Цитата Сообщение от Klayman Посмотреть сообщение
сгенерировать 8-байтовое целочисленное значение
C++
double d = rand();
0
Модератор
Эксперт С++
 Аватар для zss
13774 / 10967 / 6491
Регистрация: 18.12.2011
Сообщений: 29,248
26.11.2015, 16:15
SatanaXIII, оно конечно, получится 8 байтное число. Однако диапазон будет от нуля до RAND_MAX, которое равно максимальному 16 разрядному числу.
Надо пользоваться новым стандартом генерации случайных чисел, я в нем, к сожалению пока не специалист.
Приведу пример из
http://www.cplusplus.com/refer... tribution/
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
// uniform_real_distribution
#include <iostream>
#include <random>
 
int main()
{
  const int nrolls=10000;  // number of experiments
  const int nstars=95;     // maximum number of stars to distribute
  const int nintervals=10; // number of intervals
 
  std::default_random_engine generator;
  std::uniform_real_distribution<double> distribution(0.0,1.0);
 
  int p[nintervals]={};
 
  for (int i=0; i<nrolls; ++i) {
    double number = distribution(generator);
    ++p[int(nintervals*number)];
  }
 
  std::cout << "uniform_real_distribution (0.0,1.0):" << std::endl;
  std::cout << std::fixed; std::cout.precision(1);
 
  for (int i=0; i<nintervals; ++i) {
    std::cout << float(i)/nintervals << "-" << float(i+1)/nintervals << ": ";
    std::cout << std::string(p[i]*nstars/nrolls,'*') << std::endl;
  }
 
  return 0;
}
2
221 / 166 / 47
Регистрация: 17.07.2012
Сообщений: 587
26.11.2015, 16:17
Klayman,
C++
1
unsigned long long element = (((unsigned long long)rand() << 32) | (unsigned)rand());
1
0 / 0 / 1
Регистрация: 14.10.2015
Сообщений: 13
26.11.2015, 16:18  [ТС]
Результат будет в диапазоне int типа... Я имел в виду про весь диапазона значений, которые может содержать тип double, или unsigned long long, не важно что, главное 8 байт, и методе их заполнения псевдорандомом.
0
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
26.11.2015, 16:52
C++
1
2
3
4
5
6
7
8
#include <climits>
#include <random>
#include <chrono>
 
  std::default_random_engine g(std::chrono::system_clock::now().time_since_epoch().count());
  std::uniform_int_distribution<unsigned long long> distribution(0, ULLONG_MAX);
 
unsigned long long number = distribution(g);
1
0 / 0 / 1
Регистрация: 14.10.2015
Сообщений: 13
26.11.2015, 17:51  [ТС]
Цитата Сообщение от nmcf
C++
1
2
3
4
5
6
7
8
#include <climits>
#include <random>
#include <chrono>
 
  std::default_random_engine g(std::chrono::system_clock::now().time_since_epoch().count());
  std::uniform_int_distribution<unsigned long long> distribution(0, ULLONG_MAX);
 
unsigned long long number = distribution(g);
Спасибо, использую, но надо еще понять, как пользоваться этой библиотекой...
0
Диссидент
Эксперт C
 Аватар для Байт
27714 / 17332 / 3810
Регистрация: 24.12.2010
Сообщений: 38,978
26.11.2015, 19:09
Klayman, Можно сделать 2 rand() подряд и один из них промасштабировать...
Типа x = 2n*rand() + rand()
(n подбери сам)
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
26.11.2015, 19:09
Помогаю со студенческими работами здесь

64 отдельных бита в одно 64-битное значение
Всем привет! Нашел одну статейку.. И там в одном из пунктов нужно сделать вот это. Как это сделать т.е. строку вида...

Преобразовать BitArray в одно 64-битное значение
Приветствую всех! Прочитал на Хабре статью про сравнение изображений, кому интересно, вот ссылка Выглядит похоже. Как работает...

Ошибка конвертации в 32-битное целое значение
Помогите, пожалуйста: необходимо написать одну программу, и, вроде, я всё делаю, правильно (одна из первых проб), но как избавиться от...

Перевести 32-битное изображение в 24-битное
Возможно ли на C# перевести 32 битное изображение в 24 битное изображение и если да то как это сделать?

Сгенерировать матрицу так, чтобы в 1-м столбце матрицы было значение Х, во 2-м – значение Y=SinX
Сгенерировать матрицу А(N,2), где N – заданное натуральное число, таким обра-зом, чтобы в 1-м столбце матрицы было значение Х, во 2-м –...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
Использование значений реквизитов справочника в документе, с определенными условиями и правами
Maks 07.04.2026
1. Контроль срока действия договора Алгоритм из решения ниже реализован на примере нетипового документа "ЗаявкаНаРаботу", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если. . .
Доступность команды формы по условию
Maks 07.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: сделать доступной кнопку (команда формы "ЗавершитьСписание") при. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru