亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? fcfs.cpp

?? 鏈接指針:按照進程到達系統的時間將處于就緒狀態的進程連接成衣個就緒隊列。指針指出下一個到達進程的進程控制塊首地址。最后一個進程的鏈接指針為NULL。 估計運行時間:可由設計者任意指定一個時間值。
?? CPP
字號:
// 時間片輪轉調度算法
#include<iostream>
#include<cstdio>
#include<cmath>
#include<cstring>

using namespace std;
enum STATUS {RUN,READY,WAIT,FINISH};

struct PCBNode
{		
	int  processID;	          //進程ID
	STATUS  status;	          //進程狀態
	int  priorityNum;	      //優先數
	int  reqTime;             //總的需要運行時間
	int  remainTime;          //剩下需要運行時間
	int  arriveTime;          //進入就緒隊列時間
	int  startTime;           //開始運行時間
	int  finishTime;          //結束運行時間
	int  totalTime;           //周轉時間
    float  weightTotalTime;	  //帶權周轉時間	
};

struct QueueNode 
{
	int ID;          //進程ID
	struct QueueNode * next;   //隊列中下一個進程指針
};

struct LinkQueue
{
	QueueNode *head;//隊首
};

void Fcfs(LinkQueue& Q,int& totalTimeSum, int& weightTotalTimeSum,PCBNode * ProcessTable);
//先來先服務算法
void InitialQueue(LinkQueue& Q,PCBNode * ProcessTable,const int processnum);

void Input(PCBNode * ProcessTable, const int processnum);

int main()
{
	LinkQueue Q;
	Q.head = NULL;
    const int processnum = 16;
	const int Round = 1;
	int totalTimeSum = 0;
	int	WeightTotalTimeSum = 0;
	PCBNode * ProcessTable=new PCBNode[processnum];
	
	Input(ProcessTable, processnum);
	InitialQueue(Q, ProcessTable, processnum);
	Fcfs(Q, totalTimeSum,WeightTotalTimeSum,ProcessTable);
	cout<<"先來先服務的平均周轉時間為:"<<totalTimeSum/processnum<<endl;
	cout<<"先來先服務的平均帶權周轉時間為:"<<WeightTotalTimeSum/processnum<<endl;

	delete [] ProcessTable;

	system("Pause");
	if(getchar()=='y')
		getchar();
	return 0;
}



void Fcfs(LinkQueue& Q, int& totalTimeSum, int& weightTotalTimeSum,PCBNode * ProcessTable)
{
	totalTimeSum = 0;
	weightTotalTimeSum = 0;//平均周轉時間
	QueueNode* p;
	QueueNode* q;
	
	p = Q.head->next;
	if (p !=NULL ) 
	{
		ProcessTable[p->ID].startTime = ProcessTable[p->ID].arriveTime;
		ProcessTable[p->ID].finishTime = ProcessTable[p->ID].arriveTime + ProcessTable[p->ID].reqTime;
	}
	
	for(q=p->next; q!=NULL; q=q->next)
	{
		
		if (ProcessTable[q->ID].arriveTime < ProcessTable[p->ID].finishTime)
		{
			ProcessTable[q->ID].startTime = ProcessTable[p->ID].finishTime;
			ProcessTable[q->ID].finishTime = ProcessTable[p->ID].finishTime + ProcessTable[q->ID].reqTime;
		}
		else//下個進程到達時間較晚
		{
			ProcessTable[q->ID].startTime = ProcessTable[q->ID].arriveTime;
			ProcessTable[q->ID].finishTime = ProcessTable[q->ID].arriveTime + ProcessTable[q->ID].reqTime;
		}
		p = q;
	}
	
	for(q=Q.head->next; q!=NULL; q=q->next)
	{
		ProcessTable[q->ID].totalTime = ProcessTable[q->ID].finishTime - ProcessTable[q->ID].arriveTime;
		ProcessTable[q->ID].weightTotalTime = ProcessTable[q->ID].totalTime/ProcessTable[q->ID].reqTime;		
		totalTimeSum += ProcessTable[q->ID].totalTime;
		weightTotalTimeSum += ProcessTable[q->ID].weightTotalTime;
	}	
	
	int t = 0;
	for(q=Q.head->next; q!=NULL; q=q->next)
	{
		cout<<"*********************"<<endl;
		while ( t<ProcessTable[q->ID].finishTime )
		{
			cout<<"時刻"<<t<<":  進程"<<q->ID<<"活動"<<endl;
			t++;
		}
		if (q->next != NULL)
		{	
			cout<<"時刻"<<t<<":  進程"<<q->ID<<"結束活動,開始下一個進程."<<endl;
			cout<<"進程"<<q->ID<<"的周轉時間為: "<<ProcessTable[q->ID].totalTime<<endl;
			cout<<"進程"<<q->ID<<"的帶權周轉時間為: "<<ProcessTable[q->ID].weightTotalTime<<endl<<endl;
		}
		else
		{
			cout<<"時刻"<<t<<":  進程"<<q->ID<<"結束活動."<<endl<<endl;
			cout<<"進程"<<q->ID<<"的周轉時間為: "<<ProcessTable[q->ID].totalTime<<endl;
			cout<<"進程"<<q->ID<<"的帶權周轉時間為: "<<ProcessTable[q->ID].weightTotalTime<<endl<<endl;			
		}
	}
	cout<<"所有進程結束活動."<<endl<<endl;

	p = Q.head;
	for(q=p->next; q!=NULL; q=q->next)
	{
		delete p;
		p = q;
	}
}

void InitialQueue(LinkQueue& Q, PCBNode * ProcessTable,const int processnum)
{
	//初始化
	
	for (int i=0;i<processnum;i++)
	{
		ProcessTable[i].processID=i;
		ProcessTable[i].reqTime=ProcessTable[i].remainTime;
		ProcessTable[i].finishTime=0;
		ProcessTable[i].startTime=0;	
		ProcessTable[i].status=WAIT;
		ProcessTable[i].totalTime=0;
		ProcessTable[i].weightTotalTime=0;		
	}
	
	Q.head = new QueueNode;
	Q.head->next = NULL;
	QueueNode * p;
	QueueNode * q;
	for (i=0;i<processnum;i++)
	{	
		p = new QueueNode;
		p->ID = i;
		p->next = NULL;
		if (i == 0)
		{
			Q.head->next = p;			
		}
		else
			q->next = p;
		
		q = p;
	}
}


void Input(PCBNode * ProcessTable, const int processnum)
{
	FILE *fp;		//讀入線程的相關內容
	if((fp=fopen("input.txt","r"))==NULL)
	{
		cout<<"can not open file!"<<endl;
		exit(0);
	}		
	for(int i=0;i<processnum;i++)
	{
		fscanf(fp,"%d %d %d",&ProcessTable[i].arriveTime,&ProcessTable[i].remainTime,&ProcessTable[i].priorityNum);
	}
	fclose(fp);
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩欧美一级二级| 国产精品成人免费| 色国产综合视频| 国产不卡视频在线播放| 国产在线精品一区二区夜色| 男人操女人的视频在线观看欧美| 亚洲第一久久影院| 日产欧产美韩系列久久99| 日韩黄色片在线观看| 丝袜美腿亚洲一区| 人妖欧美一区二区| 国产一区二区网址| 亚洲欧美日韩一区二区 | 在线观看免费成人| 日韩欧美一区二区三区在线| 欧美中文字幕一区二区三区亚洲| 欧美影视一区二区三区| 欧美欧美午夜aⅴ在线观看| 欧美猛男gaygay网站| 日韩女优视频免费观看| 久久久久久久性| 亚洲天堂福利av| 日韩不卡免费视频| 国产一区二区伦理| 色综合久久中文字幕| 在线综合视频播放| 国产欧美日韩亚州综合| 亚洲一区二区视频在线观看| 日韩av一区二| www..com久久爱| 91精品蜜臀在线一区尤物| 久久久噜噜噜久久人人看| 亚洲男同性恋视频| 久久国产三级精品| 日本道免费精品一区二区三区| 91精品国产一区二区三区香蕉| 国产亚洲污的网站| 午夜天堂影视香蕉久久| 国产盗摄视频一区二区三区| 在线国产亚洲欧美| 亚洲国产成人午夜在线一区| 亚洲成人三级小说| 欧美系列亚洲系列| 久久品道一品道久久精品| 亚洲精品日韩专区silk| 久久97超碰色| 日本福利一区二区| 中文在线免费一区三区高中清不卡| 亚洲第一av色| 99久久精品费精品国产一区二区| 日韩一卡二卡三卡国产欧美| 亚洲激情综合网| 福利一区二区在线观看| 宅男噜噜噜66一区二区66| 亚洲精品中文在线影院| 国产99久久久久| 精品成人佐山爱一区二区| 亚洲午夜av在线| 色综合久久天天| 国产精品萝li| 国产精品18久久久久久久久 | 国产精品乱码久久久久久 | 欧美精品一区二区三区蜜臀| 亚洲午夜羞羞片| 色妞www精品视频| 美女任你摸久久| 欧美亚洲高清一区| 亚洲麻豆国产自偷在线| 菠萝蜜视频在线观看一区| 久久久亚洲精华液精华液精华液| 日韩主播视频在线| 91精品国产综合久久婷婷香蕉| 亚洲在线成人精品| 在线观看免费亚洲| 亚洲午夜久久久久久久久久久| 91美女精品福利| 亚洲精品五月天| 欧美在线观看视频一区二区| 亚洲一区二区三区四区在线观看| 99热在这里有精品免费| 国产精品视频你懂的| 成人app软件下载大全免费| 一本一道久久a久久精品 | 国产高清一区日本| 久久综合国产精品| 国产精品一区二区视频| 久久精品夜夜夜夜久久| 国产a久久麻豆| 亚洲视频一二三| 欧美午夜不卡视频| 日韩一区欧美二区| 国产亚洲欧美在线| av动漫一区二区| 亚洲小说欧美激情另类| 在线不卡中文字幕播放| 精品一区二区国语对白| 欧美国产亚洲另类动漫| 日本二三区不卡| 美女诱惑一区二区| 中文字幕精品一区| 欧美视频一区二区三区在线观看| 奇米888四色在线精品| 三级欧美韩日大片在线看| 色哟哟在线观看一区二区三区| 亚洲一区在线免费观看| 欧美成人性战久久| 91麻豆国产在线观看| 亚洲一区二区三区爽爽爽爽爽| 欧美久久久久久蜜桃| 国产露脸91国语对白| 亚洲精品视频在线看| 精品久久人人做人人爱| 91麻豆免费看片| 久久成人久久鬼色| 亚洲人一二三区| 久久久久一区二区三区四区| 欧美自拍偷拍一区| 色婷婷精品久久二区二区蜜臂av| 天堂在线亚洲视频| 国产精品久99| 日韩精品中文字幕在线不卡尤物| 色哟哟国产精品免费观看| 麻豆成人免费电影| 亚洲图片欧美综合| 色婷婷av一区| 欧美性videosxxxxx| 九九**精品视频免费播放| 亚洲精品老司机| 欧美精品一区二区三区四区| 欧美性大战久久| 99精品视频在线播放观看| 韩国成人在线视频| 香蕉影视欧美成人| 亚洲天堂中文字幕| 国产精品久久久久久久久图文区| 欧美一区二区三区在线电影| 日本高清视频一区二区| 99免费精品在线| 国产高清精品网站| 狠狠色丁香九九婷婷综合五月| 亚洲图片欧美一区| 亚洲综合色区另类av| 中文字幕一区二区三中文字幕| 久久丝袜美腿综合| 精品国产一区二区在线观看| 91精品国产品国语在线不卡| 欧美三级乱人伦电影| 欧美四级电影网| 欧美在线观看视频在线| 欧美主播一区二区三区| 91成人国产精品| 欧美在线一区二区三区| 在线观看视频一区二区欧美日韩| 91蜜桃免费观看视频| 色综合久久综合网欧美综合网| 国产麻豆视频精品| 亚洲国产欧美在线人成| 一区二区三区在线观看动漫| 成人免费在线视频观看| 亚洲天天做日日做天天谢日日欢 | 亚洲激情欧美激情| 综合中文字幕亚洲| 一区二区高清免费观看影视大全| 亚洲精品乱码久久久久久久久| 夜色激情一区二区| 肉色丝袜一区二区| 久久综合综合久久综合| 国产综合久久久久久久久久久久| 国产精品资源网| 99re热视频精品| 欧美日韩一区二区三区四区| 欧美丰满美乳xxx高潮www| 日韩久久久精品| 国产精品免费丝袜| 亚洲电影一级黄| 精品一区二区三区的国产在线播放| 国产美女一区二区| 日韩精品一级中文字幕精品视频免费观看 | 国产精品美女久久久久久久久久久| 中文在线一区二区| 亚洲一区中文日韩| 精品夜夜嗨av一区二区三区| 成人免费毛片高清视频| 欧美亚洲高清一区二区三区不卡| 欧美一区二区女人| 国产精品的网站| 奇米精品一区二区三区四区| 国产精品亚洲专一区二区三区| 91国在线观看| 久久久久久久久伊人| 一区二区在线电影| 国产馆精品极品| 欧美做爰猛烈大尺度电影无法无天| 精品日韩在线观看| 亚洲精品国产精华液| 国产黄人亚洲片| 欧美日韩亚洲综合在线 欧美亚洲特黄一级 | 亚洲精品美国一| 另类中文字幕网| 欧美性猛交xxxx黑人交|