最高优先级html
#include<stdio.h>post
#include<stdlib.h>htm
#include<string.h>blog
#define Max 100排序
typedef struct pcb进程
{get
char name[Max]; //进程名string
int priority; //优先级it
int arrtime; //到达时间io
int needtime; //须要运行时间
int usedtime; //已用时间
char state; //进程状态
}PCB;
PCB pcb[Max];
int n=1;
int pTime; //时间片
char SelectMenu();
void Input();
void Sort();
void Print();
void Attemper();
char SelectMenu()
{
char select;
printf("功能菜单:");
printf("\n 1.增长并调度进程");
printf("\n 2.打印进程");
printf("\n 3.退出");
printf("\n请输入你的选择(1--3):");
do{
select=getchar();
}while(select!='1'&&select!='2'&&select!='3');
return select;
}
void main()
{
int choice;
n=1;
printf(" \n");
printf("\t\t欢迎使用进程调度模拟\n\n");
choice=SelectMenu();
do{
if(choice=='1')
{
printf(" \n");
printf("请设置时间片的大小:");
scanf("%d",&pTime);
Input();
Print();
Attemper();
}
if(choice=='2')
{
Print();
}
if(choice=='3')
{
return;
}
choice=SelectMenu();
}while(1);
}
void Input()
{
do{
printf("\n---请输入第%d个进程进程---\n",n);
printf("\n进程名:");
scanf("%s",pcb[n].name);
printf("进程优先级:");
scanf("%d",&pcb[n].priority);
printf("进程须要的时间:");
scanf("%d",&pcb[n].needtime);
pcb[n].arrtime=n;
pcb[n].usedtime=0;
pcb[n].state='W';
n++;
}while(n<5);
}
void Sort()
{
int i,j;
PCB temp;
for(i=0;i<n-1;i++) //按照到达时间排序
{
for(j=n-2;j>=i;j--)
{
if(pcb[j+1].arrtime<pcb[j].arrtime)
{
temp=pcb[j];
pcb[j]=pcb[j+1];
pcb[j+1]=temp;
}
}
}
for(i=0;i<n-1;i++) //按照优先级排序
{
for(j=n-2;j>=i;j--)
{
if(pcb[j+1].priority>pcb[j].priority)
{
temp=pcb[j];
pcb[j]=pcb[j+1];
pcb[j+1]=temp;
}
}
}
if(pcb[0].state!='F')
{
pcb[0].state='R';
}
}
void Print()
{
int i;
Sort();
printf("\n 进程名 优先级 到达时间 须要时间 已用时间 进程状态 \n");
for(i=0;i<n;i++)
{
printf("%8s%8d %8d %10d %10d %10c\n",pcb[i].name,pcb[i].priority,pcb[i].arrtime,pcb[i].needtime,pcb[i].usedtime,pcb[i].state);
}
}
void Attemper()
{
do{
if((pcb[0].needtime-pcb[0].usedtime)>pTime) //判断进程剩余的运行时间是否大于时间片
{
pcb[0].usedtime+=pTime;
pcb[0].priority--;
pcb[0].state='W';
}
else //已完成的进程
{
pcb[0].usedtime=pcb[0].needtime;
pcb[0].priority=-1;
pcb[0].state='F';
}
Print();
}while(pcb[0].state!='F');
}