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

Потоки - 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, double c,double i) { double f;
C++ Центрирование строк в текстовом файле Длина строк текстового файла не может превышать 80 символов. Нужно разместить все эти строки по центру. Вроде как идея такая... Сначала считаем количество пробелов слева. Потом определяем длину строки за вычетом левых пробелов.Исходя из того, что строка должна иметь длину в 80 символов, подсчитываем сколько пробелов нужно добавить (слева и справа). Добавляем нужное количество пробелов слева к... http://www.cyberforum.ru/cpp-beginners/thread120322.html
пифагоровы тройки,безцелочисленное деление и другое C++
Пожалуйста ,помогите!Задача: 1) Дано натуральное число .Записать его в обратном порядке не применяя операцмю целочислового деления. 2) найти все двойки натурального числа n ,если они существуют n=x*x*x+y*y*y Заранее спасибо!
Использование memcpy в трехмерном массиве C++
Есть трехмерный массив int massiv={0}; нужно с помощью memcpy переместить два элемента massiv=1; massiv=1; на место
C++ Написание программ на C! массивы и матрицы http://www.cyberforum.ru/cpp-beginners/thread120310.html
Доброго времени суток!Срочно нужна помощь новичку в программировании по С.Требуется написать 2 програмы: 1.Задан массив целочисленных двухбайтовых знаковых элементов.Необходимо сформировать новый массив элементы которого формируются по правилу a*=D*A+B. Коэффициеты вычисляются так: D*amax+B=1 D*amin+B=-1 2.Задана квдратная матрица.Необходимо сформировать 2а одномерных массива. В 1ый...
C++ Преобразование слов Каждая буква задана числом: а=1; б=2; в=3; г=4; д=5; е=6; ё=7; ж=8; з=9; подробнее

Показать сообщение отдельно
Horrorous
0 / 0 / 0
Регистрация: 13.04.2009
Сообщений: 38
22.04.2010, 03:26     Потоки
Доброго времени суток!

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

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

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

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;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 18:45. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru