Форум программистов, компьютерный форум, киберфорум
C/С++ под Linux
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
0 / 0 / 0
Регистрация: 07.12.2013
Сообщений: 2

Задача о курильщиках

16.01.2014, 07:29. Показов 1554. Ответов 0
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте, уважаемые форумчане.
Имеется следующая задача, написать программу для решения задачи о трех курильщиках на С под Linux.
Решить необходимо с использованием потоков, мьютексов и условных переменных. Написал такой вод код.
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
#include <pthread.h> 
#include <stdlib.h> 
#include <stdio.h> 
#include <unistd.h>
 
int ingr[3];//наличие ингридиентов
int choice=0;
pthread_mutex_t sync1;
pthread_cond_t con;
 
 
 
void* makler()
{   
    int a;
    int i;
    while(1)
    {
    pthread_mutex_lock(&sync1);
    while (choice==0) pthread_cond_wait(&con,&sync1);
    
    for (i = 0; i<3; i++)
    {
    ingr[i] = 0;//ингридиентов у посредника нет
    }
    
    choice = rand ()%3+1;//выбор курильщика у которого ингридиенты браться не будут    
    
    for (i = 0; i<3; i++)
    {
    if (i!=(choice-1))
    ingr[i]= 1;//берем ингридиент
    }
    
    switch(choice)
    {
        case 1: printf("Makler takes paper and lighter\n"); break;        
        case 2: printf("Makler takes tobacco and lighter\n"); break;          
        case 3: printf("Makler takes tobacco and paper\n"); break;
    }
    
    pthread_cond_signal(&con);
                
    pthread_mutex_unlock(&sync1);
    }
}
 
void* first_smoker()
{
    while(1)
    {
    pthread_mutex_lock(&sync1);
    while (choice==0) pthread_mutex_lock(&sync1);
    pthread_cond_wait(&con,&sync1);      
        printf("Smoking first smoker\n"); 
    pthread_cond_signal(&con);              
    pthread_mutex_unlock(&sync1);
    }
}
 
void* second_smoker()
{
    while(1)
    {
    pthread_mutex_lock(&sync1);
    if (choice==2) pthread_cond_wait(&con,&sync1);      
        printf("Smoking second smoker\n"); 
    pthread_cond_signal(&con);              
    pthread_mutex_unlock(&sync1);
    }
}
 
void* third_smoker()
{
    while(1)
    {
    pthread_mutex_lock(&sync1);
    if (choice==3) pthread_cond_wait(&con,&sync1);      
        printf("Smoking third smoker\n"); 
    pthread_cond_signal(&con);              
    pthread_mutex_unlock(&sync1);
    }
}
 
main()
{
    
    pthread_t mk,fs,ss,ts;
    pthread_attr_t attr;
    pthread_attr_init(&attr);
    pthread_mutex_init(&sync1,NULL);
    pthread_cond_init(&con,NULL);
    pthread_create(&mk,&attr,makler, NULL);
    pthread_create(&fs,&attr,first_smoker,NULL);    
    pthread_create(&ss,&attr,second_smoker,NULL);   
    pthread_create(&ts,&attr,third_smoker,NULL);
    pthread_join(mk,NULL);
    pthread_join(fs,NULL);
    pthread_join(ss,NULL);
    pthread_join(ts,NULL);
    for(;;){};
}
В результате, код компилится без проблем, но при запуске программа ничего не выдает.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
16.01.2014, 07:29
Ответы с готовыми решениями:

Задача о курильщиках C++ Linux
1. Есть три заядлых курильщика, сидящих за столом. Каждому из них доступно бесконечное количество одного из трёх компонентов: у одного...

Олимпиадная задача по программированию. PascalABC.NET. Задача L. Переключение между окнами
Когда пользователь работает в операционной системе Winux, у него часто запущено несколько приложений. Каждое из приложений работает в...

Васильев C# Глава 7 задача 8 (Просьба объяснить формулировку(задача внутри)
Текст задачи Напишите программу с классом, у которого есть текстовое поле. Значение текстовому полю присваивается при создании объекта...

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
16.01.2014, 07:29
Помогаю со студенческими работами здесь

Васильев C# Глава 8 задача 2 (Просьба объяснить формулировку(задача внутри)
Текст задачи Написать программу , в которой есть класс с полем, являющимся ссылкой на одномерный целочисленный массив. У класса есть...

В некотором государстве ввели компьютерный паспорт гражданина. Укажите пол гражданина и последовательность событий
Доброго времени суток,форумчане. Хотелось бы попросить помощи в решении одной задачи от умных голов. Задача: В некотором...

Считалка. Олимпиадная задача по программированию
Ирочка попросила маму придумать новую считалочку. Мама тут же ей &quot;выдала&quot;. Пусть в кругу N человек. Это число N будем изменять...

Задача на перебор вариантов. Задача Л.Эйлера. Про чиновника
Задача Л.Эйлера. Некий чиновник купил лошадей и быков на сумму 1770 талеров. За каждую лошадь он уплатил по 31 талеру, а за каждого быка по...

Задача на k-тую цифру последовательности, задача на схему Горнера.
Ну, собственно опять прошу помощи... Задача 1: Определить k-тую цифру последовательности 1234567891011121314…, в которой выписаны подряд...


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
Программный контроль заполнения реквизита табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать контроль заполнения реквизита "ПричинаСписания". . .
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение: DISM / Online / Add-Capability / CapabilityName:WMIC~~~~ Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
Программная установка даты и запрет ее изменения
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: при создании документов установить период списания автоматически. . .
Вывод данных в справочнике через динамический список
Maks 01.04.2026
Реализация из решения ниже выполнена на примере нетипового справочника "Спецтехника" разработанного в конфигурации КА2. Задача: вывести данные из ТЧ нетипового документа. . .
Программное заполнения текстового поля в реквизите формы документа
Maks 01.04.2026
Алгоритм из решения ниже реализован на нетиповом документе "ВыдачаОборудованияНаСпецтехнику" разработанного в конфигурации КА2, в дополнении к предыдущему решению. На форме документа создается. . .
К слову об оптимизации
kumehtar 01.04.2026
Вспоминаю начало 2000-х, университет, когда я писал на Delphi. Тогда среди программистов на форумах активно обсуждали аккуратную работу с памятью: нужно было следить за переменными, вовремя. . .
Идея фильтра интернета (сервер = слой+фильтр).
Hrethgir 31.03.2026
Суть идеи заключается в том, чтобы запустить свой сервер, о чём я если честно мечтал давно и давно приобрёл книгу как это сделать. Но не было причин его запускать. Очумелые учёные напечатали на. . .
Модель здравосоХранения 6. ESG-повестка и устойчивое развитие; углублённый анализ кадрового бренда
anaschu 31.03.2026
В прикрепленном документе раздумья о том, как можно поменять модель в будущем
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru