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

Потоки - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ нужно исправить выдает не верный ответ http://www.cyberforum.ru/cpp-beginners/thread120325.html
вот то что я сделал , но сдесь наверное что то не так с условием #include<iostream> #include<math.h> #include<clocale> using namespace std; // подпрограмма double fun ( double a,double b,...
C++ Центрирование строк в текстовом файле Длина строк текстового файла не может превышать 80 символов. Нужно разместить все эти строки по центру. Вроде как идея такая... Сначала считаем количество пробелов слева. Потом определяем длину... http://www.cyberforum.ru/cpp-beginners/thread120322.html
пифагоровы тройки,безцелочисленное деление и другое C++
Пожалуйста ,помогите!Задача: 1) Дано натуральное число .Записать его в обратном порядке не применяя операцмю целочислового деления. 2) найти все двойки натурального числа n ,если они существуют...
Использование memcpy в трехмерном массиве C++
Есть трехмерный массив int massiv={0}; нужно с помощью memcpy переместить два элемента massiv=1; massiv=1; на место
C++ Написание программ на C! массивы и матрицы http://www.cyberforum.ru/cpp-beginners/thread120310.html
Доброго времени суток!Срочно нужна помощь новичку в программировании по С.Требуется написать 2 програмы: 1.Задан массив целочисленных двухбайтовых знаковых элементов.Необходимо сформировать новый...
C++ Преобразование слов Каждая буква задана числом: а=1; б=2; в=3; г=4; д=5; е=6; ё=7; ж=8; з=9; подробнее

Показать сообщение отдельно
Horrorous
0 / 0 / 0
Регистрация: 13.04.2009
Сообщений: 38

Потоки - C++

22.04.2010, 03:26. Просмотров 433. Ответов 1
Метки (Все метки)

Доброго времени суток!

Задание такое

Создание списка слов отсортированных по алфавиту (выбрать алгоритм с возможностью параллельного исполнения);

вот код, уже сбился с ног ища в чем ошибка, все надо реализовать с использованием потоков

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
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
#include "stdafx.h"
 
char array[20][11];
int flag = 1;
CRITICAL_SECTION CriticalSection; 
HANDLE hMutex;
 
 
DWORD WINAPI MyThreadFun1(PVOID _pParam)
{
    int *l = (int*)_pParam, i = *l;
 
 
    WaitForSingleObject(hMutex, INFINITE);
    if(strcmp(array[i],array[i+1])>0)
        {
            char buffer[11];
            strcpy(buffer,array[i]);
            strcpy(array[i],array[i+1]);
            strcpy(array[i+1],buffer);
            flag = 1;
        } 
 
    ReleaseMutex(hMutex);
    return 0;
}
 
 
//DWORD WINAPI MyThreadFunMutex(PVOID _pParam)
//{
//  int *n = (int*)_pParam,
//      j = *n;
//
//
//  WaitForSingleObject(hMutex, INFINITE);
//  // Вот сдесь синхронизпация
//  Sleep(2000);
//  ++(*n);
//  printf(" %d ", *n);
//
//  ReleaseMutex(hMutex);
//
//  return 0;
//}
 
int _tmain(int argc, _TCHAR* argv[])
{
    int *n = new int(), *n2 = new int();
    char str[101]; 
    printf("Vvedite slova: "); 
    gets(str);
    
    int count = 0; 
    char *ptr = strtok(str,"\t ");
    for(count=0; ptr!=NULL; count++)
    {
        strcpy(array[count], ptr);
        ptr = strtok(NULL,"\t ");
    }
    printf("%d\n", count);
    const int l = count;
 
    HANDLE hThreads[7];
    HANDLE hMutex = ::CreateMutex(NULL, FALSE, NULL);
 
    LARGE_INTEGER freq;
    QueryPerformanceFrequency(&freq);
 
    LARGE_INTEGER time1;
    QueryPerformanceCounter(&time1);
 
    while(flag){   
    flag = 0; 
    for(int i = 0;i<count-1;i++){
        hThreads[i] = ::CreateThread(NULL, 0, MyThreadFun1, n, 0, NULL);}
    }
 
    for(int i = 0;i<count-1;i++)
    {
        WaitForSingleObject(hThreads[i], INFINITE);
        CloseHandle(hThreads[i]);
    }
 
 
    LARGE_INTEGER time2;
    QueryPerformanceCounter(&time2);
    time2.QuadPart -= time1.QuadPart;
 
double span = (double) time2.QuadPart / freq.QuadPart;
printf("Time: %f ns\n", span*1000000000);
 
    strcpy(str,"");
    for(int i=0;i<count;i++)
    {
        strcat(str,array[i]);
        strcat(str," ");
    }
    puts("Result: \n"); puts(str);
    int c;
    scanf("%d", &c);
 
 
 
 
 
    //сюда пока не лезть
    /*HANDLE hThread;
 
    hThread = ::CreateThread(NULL, 0, MyThreadFun, n, 0, NULL);
 
    WaitForSingleObject(hThread, INFINITE);
 
    CloseHandle(hThread);
 
    HANDLE hThreads[10];*/
 
    /*hMutex = ::CreateMutex(NULL, FALSE, NULL);
    
    for (int i = 0; i < 10; i++)
        hThreads[i] = ::CreateThread(NULL, 0, MyThreadFunMutex, n, 0, NULL);
 
    for (int i = 0; i < 10; i++)
    {
        WaitForSingleObject(hThreads[i], INFINITE);
        CloseHandle(hThreads[i]);
    }*/
 
 
    return 0;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.