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

C++

Войти
Регистрация
Восстановить пароль
 
'HelloWorld'
0 / 0 / 0
Регистрация: 15.11.2009
Сообщений: 31
#1

ГСЧ для float из всего диапазона - C++

21.03.2011, 12:29. Просмотров 991. Ответов 2
Метки нет (Все метки)

Ребят, подскажите, пожалуйста, как можно сгенерировать число типа float из всего диапазона данного типа? Причем, если получится NaN, +Inf, -Inf перегенерировать это число? Как можно реализовать данную проверку?
Заранее спасибо.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
21.03.2011, 12:29
Здравствуйте! Я подобрал для вас темы с ответами на вопрос ГСЧ для float из всего диапазона (C++):

создать файл вещ. чисел используя ГСЧ - Visual C++
Используя генератор случайных чисел создать файл вещ.чисел из сегмента . Значения a и b задаются пользователем.

Умещение диапазона в float - C++
Задано количество точек n, расположенных через равные интервалы. Необходимо вычислить диапазон float для данного количества точек, так,...

опять ошибка.на этот раз cannot convert `float (*)(float)' to `float' in argument passing - C++
#include<stdio.h> #include<stdlib.h> #include<math.h> float f1(float x)/*vira*enie 1*/ {return (x*cos(x))/(1+ pow(x,2));} ...

ГСЧ для равномерного распределения случайных чисел на заданном интервале - C++
Доброго всем времени суток. Мне нужно получить последовательность случайных чисел типа double равномерно распределённых на заданном...

"Значение типа float* нельзя использовать для инициализации сущности типа float" - C++
#include <math.h> #include<iostream> #include <iomanip> #include<conio.h> using namespace std; ...

Чем отличаются float преобразования (float)var от float(var) - C++
Здравствуйте! Подскажите, чем отличается (float)var от float(var)

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Mr.X
Эксперт С++
3049 / 1694 / 265
Регистрация: 03.05.2010
Сообщений: 3,867
21.03.2011, 18:40 #2
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
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
/////////////////////////////////////////////////////////////////////////////////////////
//как можно сгенерировать число типа float из всего диапазона данного типа? Причем, 
//если получится NaN, +Inf, -Inf перегенерировать это число? Как можно реализовать 
//данную проверку?
/////////////////////////////////////////////////////////////////////////////////////////
#include <cstdlib>
#include <ctime>
#include <iostream>
#include <limits>
#include <sstream>
#include <string>
/////////////////////////////////////////////////////////////////////////////////////////
typedef std::string  T_str;
/////////////////////////////////////////////////////////////////////////////////////////
template<class T_num>
T_num  get_val_in_segment(T_num  min, T_num  max)
{
    return  rand() % (max - min + 1) + min;
}
/////////////////////////////////////////////////////////////////////////////////////////
struct  T_gen_rand_float
{
    int  digits10_;
    int  min_exponent10_;
    int  max_exponent10_;
    //-----------------------------------------------------------------------------------
    T_gen_rand_float() 
        : digits10_        (std::numeric_limits<float>::digits10),
          min_exponent10_  (std::numeric_limits<float>::min_exponent10),
          max_exponent10_  (std::numeric_limits<float>::max_exponent10)
    {}
    //-----------------------------------------------------------------------------------
    float  rand_float()
    {        
        std::stringstream  sstream;
        sstream << (rand() % 2 ? '+' : '-')
                << '.';
 
        for(int  i = 0; i < digits10_; ++i)
        {
            sstream << get_val_in_segment(0, 9);
        }
 
        sstream << 'e'
                << get_val_in_segment(min_exponent10_, max_exponent10_);
 
        float  float_res = 0;
        sstream >> float_res;           
        return  float_res;       
    }   
};
/////////////////////////////////////////////////////////////////////////////////////////
int main()
{    
    srand(static_cast<unsigned>(time(0)));
    T_gen_rand_float  gen_rand_float;
    float  f = gen_rand_float.rand_float();
    const size_t LINE_LEN = 60;
    const T_str  LINE(LINE_LEN, '=');
 
    std::cout << LINE
              << std::endl
 
              << "\t\t\tRAND OF "
              << typeid(f).name()
              << std::endl
 
              << LINE
              << std::endl
 
              << "digits10        : "
              << gen_rand_float.digits10_
              << std::endl
 
              << "min_exponent10_ : "
              << gen_rand_float.min_exponent10_
              << std::endl
 
              << "max_exponent10_ : "
              << gen_rand_float.max_exponent10_
              << std::endl
 
              << LINE
              << std::endl
 
              << "rand fixed      : "
              << std::fixed
              << f
              << std::endl
 
              << "rand scientific : "
              << std::scientific
              << f
              << std::endl
 
              << LINE
              << std::endl;    
}
NiTan
Покинул форум
3149 / 1331 / 50
Регистрация: 29.01.2010
Сообщений: 2,887
22.03.2011, 14:47 #3
slice, первый и последний раз вижу такое сообщение.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
22.03.2011, 14:47
Привет! Вот еще темы с ответами:

invalid types `float[float]' for array subscript - C++
void SEARCH(float vol, float price, int i) { if (i&gt;N) { if(price&gt;maxprice) { ...

cannot convert `float' to `float*. Почему так происходит? - C++
всем привет, помогите исправить ошибки... а то голова мало варит уже, а завтра надо сдать уже #include &lt;stdio.h&gt; #include &lt;stdlib.h&gt;...

неверное приведение void* к *float а далее к float - C++
Почему когда привожу void* к int* потом к int то все работает, данные не бьются и работают нормально, когда делаю те же операции но с...

ГСЧ - C++
А подскажите пожалуйста, как сгенерировать числа от 10 до 1000000 ? и какой тип переменной использовать, long long?


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

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

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