Форум программистов
 

Восстановите пароль или Зарегистрируйтесь на форуме, о проблемах и с заказом рекламы пишите сюда - alarforum@yandex.ru, проверяйте папку спам!

Вернуться   Форум программистов > IT форум > Помощь студентам
Регистрация

Восстановить пароль
Повторная активизация e-mail

Купить рекламу на форуме - 42 тыс руб за месяц

Ответ
 
Опции темы Поиск в этой теме
Старый 11.12.2010, 13:24   #1
ge4r
Пользователь
 
Регистрация: 25.03.2009
Сообщений: 18
По умолчанию Алгоритмы планирования FCFS и SRR в С++

Добрый день,нужно накатать 2 таких алгоритма и вычислить параметры их работы

вот FCFS попытался накатать,но он не хочет работать,видимо ошибка в методе fcfs

Зы пишу в дев-спп.


Код:
#include <iostream>
#include <stdlib.h>
 
using namespace std;
int n;
class process {
        public:
        int stime;
        int burst;
        int cburst;
        int gtime;
        int priority;
        int completed;
        int number;
        float M;
        float R;
        float P;
        
        process() {
        this->burst=0;
        this->stime=0;
        this->priority=0;
        }
        
        ~process() {};
};
 
void random (process procs[]){
        for (int i=0;i<n;i++) {
                procs[i].stime=rand() % 10;
                procs[i].burst=rand() % 100 + 1;
                procs[i].cburst=procs[i].burst;
                procs[i].completed=0;
                procs[i].number=i;
                procs[i].priority=rand()%4 +1 ;
        }
}
 
process* min_stime(process procs[]){
        int min_time = INT_MAX;
        process *min;
        for (int i=0;i<n;i++){
                if(procs[i].completed==0 && procs[i].stime<min_time){
                                min_time=procs[i].stime;
                                min=&procs[i];
                                }
                }
        return min;
}
 
void fcfs (process procs[]){
        process *cur=min_stime(procs);
        int tick=0;
        while(cur!=NULL) {
                if (cur->burst==0){
                      cur->completed=1;
                      }
                if (cur->completed==1){
                      cur->gtime=tick-cur->stime;
                      cur=min_stime(procs);
                      if (cur==NULL) break;
                      }
                if (tick>= cur->stime){
                      cur->burst--;
                      }
                tick++;
        }
}
 
void count (process procs[]){
        for (int i=0;i<n;i++){
                procs[i].M=procs[i].gtime-procs[i].cburst;
                procs[i].R=procs[i].cburst/procs[i].gtime;
                procs[i].P=1/procs[i].R;
                }
}
                
        
        
        
 
 
int main(int argc, char *argv[])
{
        cout<<"Input n: ";
        cin>>n;
        process procs[n];
        random(procs);
        fcfs(procs);
        count (procs);
        for (int i=0;i<n;i++){
                printf("M= ",procs[i].M);
                }
                
        
  
  system("PAUSE");      
  return 0;
}

Последний раз редактировалось ge4r; 11.12.2010 в 13:34.
ge4r вне форума Ответить с цитированием
Старый 12.12.2010, 11:52   #2
ge4r
Пользователь
 
Регистрация: 25.03.2009
Сообщений: 18
По умолчанию

ап,неужели никто не может помочь? вот методичка для больше ясности задачи
Вложения
Тип файла: pdf сппо-лаб6-2009-процессы.pdf (275.7 Кб, 25 просмотров)
ge4r вне форума Ответить с цитированием
Ответ


Купить рекламу на форуме - 42 тыс руб за месяц



Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
алгоритмы boomeer Общие вопросы C/C++ 6 04.12.2010 20:05
Задача планирования «в мире кубиков» Turbo prolog Ketty_byyy Помощь студентам 0 14.11.2010 12:43
проектирование базы планирования производства redfield Microsoft Office Access 0 11.06.2010 13:24
Программа планирования завода по сборки jungo Софт 1 29.07.2008 14:01