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

uniform_int_distribution или uniform_real_distribution ? - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Поиск файла по маске в несколько потоков http://www.cyberforum.ru/cpp-beginners/thread721890.html
Здравствуйте, дали задание, но я не силён в этом, помогите решить пожалуйста. Нужно сделать поиск файла по маске в несколько потоков. 1. Поиск файлов по маске в каталоге. Количество потоков равно кол-ву каталогов. Найденные файлы сохранять в памяти. После завершения поиска всеми потоками, вывести на экран найденные файлы. Средство синхронизации семафор. Если найдутся люди, которые могут...
C++ Найти количество первых целых положительных чисел, сумма которых не превышает S. Значение S вводить с клавиатуры Найти количество первых целых положительных чисел, сумма которых не превышает S. Значение S вводить с клавиатуры. желательно попроще и со scanf и printf. Заранее очень благодарен! Добавлено через 21 час 17 минут Найти количество первых целых положительных чисел, сумма которых не превышает S. Значение S вводить с клавиатуры. желательно попроще и со scanf и printf. Заранее очень благодарен!... http://www.cyberforum.ru/cpp-beginners/thread721888.html
Не могу открыть файл fstream C++
Добрый день. Не могу открыть файл с помощью fstream файл, файл лежит в корне проекта. Пользуюсь QT creator с gcc. #include <iostream> #include <fstream> #include <string> using namespace std; int main() { string line; ifstream INPUT ("input.txt");
C++ Деревья "и/или"
Помогите пожалуйста разобраться с деревьями "и/или"? Чем они существенно отличаются от простых деревьев? Если есть возможность, приведите пример кода построения дерева "и/или" на С++.
C++ Помощь с оператором std:: http://www.cyberforum.ru/cpp-beginners/thread721874.html
Помогите пожалуйста, я только начинаю изучать C++ и встретился с оператором "std::" . Кто подскажет какой это оператор, и какого его действие?!
C++ Динамические массивы Добрый вечер, у меня в программе есть динамический массив, в котором, если записать туда >20 элементов, все элементы перемешиваются, но когда я делаю массив обычным(не динамическим), все становится на свои места. Как быть и в чем проблема? подробнее

Показать сообщение отдельно
DiffEreD
 Аватар для DiffEreD
1420 / 757 / 95
Регистрация: 21.06.2011
Сообщений: 1,740
Записей в блоге: 2
06.12.2012, 23:51     uniform_int_distribution или uniform_real_distribution ?
Какая из двух функций fill_random_1 или fill_random_2 эффективней. Имеет ли смысл определять две подобных таких ф-ции или генерить рандомные числа только из uniform_real_distribution в одной ф-ции с преобразованием типа? Вот код:
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
#include <iostream>
#include <algorithm>
#include <iterator>
#include <random>
#include <type_traits>
 
template<typename T>
class Array
{
    T* m_array;
    size_t m_size;
public:
    Array() : m_array(nullptr), m_size(0) {}
    Array(size_t size, int fill = 0) : m_array(new T[size]), m_size(size) {for (size_t i = 0; i<m_size; ++i) m_array[i] = fill;}
    ~Array() {delete[] m_array;}
    void show() const {std::copy(m_array, m_array+m_size, std::ostream_iterator<T>(std::cout, " ")); std::cout<<std::endl<<std::endl;}
    void fill_random_1(int up = 0, int top = 100)
    {
        std::random_device rd;
        std::mt19937 gen(rd());
        if (up>top) std::swap(up, top);
        std::uniform_real_distribution<> real(up, top);
        std::uniform_int_distribution<> intteger(up, top);
        if (std::is_floating_point<T>::value)
        {
            //std::cout<<"floating_point\n";
            for (size_t i = 0; i<m_size; ++i) m_array[i] = real(gen);
        }
        else
        {
            //std::cout<<"integral\n";
            for (size_t i = 0; i<m_size; ++i) m_array[i] = intteger(gen);
        }
    }
 
    void fill_random_2(int up = 0, int top = 100)
    {
        std::random_device rd;
        std::mt19937 gen(rd());
        if (up>top) std::swap(up, top);
        std::uniform_real_distribution<> real(up, top);
        for (size_t i = 0; i<m_size; ++i) m_array[i] = real(gen);
    }
};
 
int main()
{
    Array<int> a_int(10);
    Array<double> b_double(10);
 
    a_int.fill_random_1();
    b_double.fill_random_1();
    a_int.show();
    b_double.show();
 
    a_int.fill_random_2();
    b_double.fill_random_2();
    a_int.show();
    b_double.show();
 
    system("pause");
    return 0;
}
Добавлено через 4 часа 9 минут
Ладно народ, более менее разобрался сам. Провел некие замеры по времени. Результат, конечно, для меня оказался неожиданным - оказывается std::uniform_int_distribution<> работает намного медленней чем std::uniform_real_distribution<> хотя по логике должно было быть наоборот. Вот результаты тестов:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
int main()
{
    const long long million = 100000000;
    Array<int> a_int(million);
    Array<double> b_double(million);
 
    clock_t t=clock();
 
    //b_double.fill_random_1();  //15
    //b_double.fill_random_2();  //15
    //a_int.fill_random_1();     //34
    //a_int.fill_random_2();     //15
 
    int time=(clock()-t)/CLOCKS_PER_SEC;
    std::cout<<"time = "<<time<<"\n";
 
    system("pause");
    return 0;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 07:46. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru