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

Массив потоков. Ошибка при закрытии программы - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Найти минимальный и максимальный элемент матрицы и вывести его на экран с указанием номеров их строк и столбцов. http://www.cyberforum.ru/cpp-beginners/thread826782.html
Найти минимальный и максимальный элемент матрицы и вывести его на экран с указанием номеров их строк и столбцов.
C++ Из задоного множества точек на плоскости выбрать две различные точки Привет всем пожалуста помогите найти ошибку в коде. условия задачи: Из задоного множества точек на плоскости выбрать две различные точки так чтобы окружности задоного радиуса с центрами в этих точках содержали внутри себя одинаковое количество заданых точек. #include <iostream> #define nmax 15 struct point { float x, y; }; http://www.cyberforum.ru/cpp-beginners/thread826779.html
C++ Разделение на файлы
Может кто-то объяснить как разделять код на файлы? (я так понял нужно создать заглавный файл ****.h , создать файл с таким же именем с расширением**** .cpp, в **** .h файле нужно сделать описание классов и записать прототипы функций; в ****.cpp их реализацию, в третьем файле только ф-я main...). Куда например нужно писать перегруженные функции? Когда использовать #define и #pragma once? ...
Удаление элемента из двусвязного списка C++
Надо удалить элемент из двусвязного списка, если выполняется условие (2013-(current->god)<3). Я пытаюсь как могу, но что то все равно косяки идут. Подскажите... #include <conio.h> #include <windows.h> #include <iostream> using namespace std; //Создать структуру с именем Sotrudnik с полями: //фамилия, имя, должность, год поступления на работу.
C++ Транспонирование одномерного массива http://www.cyberforum.ru/cpp-beginners/thread826773.html
int main() { setlocale(LC_ALL,".1251"); int mas ; int n = 0; cout <<"Введите размер массива"; cin >> n; cout << "Введите члены последовательности(через пробел):\n";
C++ сохранение в файл Всем привет. Люди добрые помогите пж сохранить введенный результат в файл. #include <iostream.h> #include <stdio.h> #include <conio.h> #include <stdlib.h> #include <string.h> FILE *fl; typedef struct подробнее

Показать сообщение отдельно
DiffEreD
 Аватар для DiffEreD
1420 / 757 / 95
Регистрация: 21.06.2011
Сообщений: 1,740
Записей в блоге: 2
03.04.2013, 22:24     Массив потоков. Ошибка при закрытии программы
Ради интереса написал шаблонную реализацию. [NovicheK], попробуйте, позасекайте время на своих 4 ядрах (на моих двух разница не особо заметна).
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
#include <functional>
#include <iostream>
#include <thread>
#include <vector>
#include <random>
#include <chrono>
#include <algorithm>
#include <iterator>
#include <ctime>
 
template<typename Iterator, typename T>
void max_el(Iterator first, Iterator last, T& result){
    result = *std::max_element(first, last);
}
 
template<typename Iterator>
typename Iterator::value_type max_element_parallel(Iterator first, Iterator last)
{
    typedef typename Iterator::value_type value_type;
    const unsigned long long length = std::distance(first, last);
    if (length<1000) return *std::max_element(first, last);
    unsigned num_thread = std::thread::hardware_concurrency();
    unsigned long long chunk_bloc = length/num_thread;    //количество элементов на поток
    
    std::vector<std::thread> threads(num_thread);
    std::vector<value_type> results(num_thread+1);
    Iterator block_start = first;
    for (unsigned i = 0; i<num_thread; ++i)
    {
        Iterator block_end = block_start;
        std::advance(block_end, chunk_bloc);
        threads[i] = std::thread(&max_el<Iterator, value_type>, block_start, block_end, std::ref(results[i]));
        block_start = block_end;
    }
    max_el<Iterator, value_type>(block_start, last, std::ref(results[num_thread]));
    for (auto& t : threads) t.join();
    
    return *std::max_element(results.begin(), results.end());
}
 
int main()
{
    const unsigned long size = 100000080;
    
    std::vector<long> data(size);
    auto rand = std::bind(std::uniform_int_distribution<long>(-1000000000, 1000000000), std::default_random_engine(time(nullptr)));
    for (long& val : data) val = rand();
    
    auto start = std::chrono::high_resolution_clock::now();
    std::cout<<"Max element is: "<<max_element_parallel(data.begin(), data.end())<<"\n";
    auto stop = std::chrono::high_resolution_clock::now();
    
    std::cout<<"Time of parallel algorithm: "<<std::chrono::duration_cast<std::chrono::milliseconds>(stop-start).count()<<"\n\n";
    
    start = std::chrono::high_resolution_clock::now();
    std::cout<<"Max element is: "<<*std::max_element(data.begin(), data.end())<<"\n";
    stop = std::chrono::high_resolution_clock::now();
    
    std::cout<<"Time of standart algorithm: "<<std::chrono::duration_cast<std::chrono::milliseconds>(stop-start).count()<<"\n";
    
    return 0;
}
 
Текущее время: 02:17. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru