Python实现调度算法代码详解实现调度算法代码详解
调度算法
操作系统管理了系统的有限资源,当有多个进程(或多个进程发出的请求)要使用这些资源时,因为资源的有限性,必须按照
一定的原则选择进程(请求)来占用资源。这就是调度。目的是控制资源使用者的数量,选取资源使用者许可占用资源或占用
资源。
在操作系统中调度是指一种资源分配,因而调度算法是指:根据系统的资源分配策略所规定的资源分配算法。对于不同的的系
统和系统目标,通常采用不同的调度算法,例如,在批处理系统中,为了照顾为数众多的段作业,应采用短作业优先的调度算
法;又如在分时系统中,为了保证系统具有合理的响应时间,应当采用轮转法进行调度。目前存在的多种调度算法中,有的算
法适用于作业调度,有的算法适用于进程调度;但也有些调度算法既可以用于作业调度,也可以用于进程调度。
目标阐述:
将中缀表达式转换为后缀表达式(Reverse Polish Notation:RPN 逆波兰式)
参与运算的数据的正则表示为:[0-9]{1,}形式的十进制数
运算符优先级:(从高到低)————————————————————————
( ) 括号
/ * % 除乘余
+ - 加减————————————————————————
解:
第一步:使用正则词法分析器flex生成一个词法分析器,以处理输入的中缀表达式。
从stdin接收输入,检测非法字符,并将处理后的中缀表达式输出到stdout。
%option noyywrap
%{
#include<stdio.h>
#include<stdlib.h>%}
%%
[0-9]+ { printf("%s ",yytext); }
[()*/%+-] { printf("%s ",yytext); }
[[:space:]] {}
. { printf("\nError");exit(1); }
%%
int main()
{
yylex();
printf("");
return 0;
}
第二步:使用Python进行转换。
从stdin接收一定格式的中缀表达式字符流,检测是否在词法分析器处理过程中出错,然后使用调度场算法处理数据,得到rpn
列表。
import sys
line=sys.stdin.readline()
line2=sys.stdin.readline()
if len(line2)>0:
sys.stderr.write("Syntax Error after : ")
sys.stderr.write(line)
sys.stderr.write("")
exit(1)
lis=line.split(' ')
lis.pop()
lis_old=lis[:] lis.reverse()
oplis=[] rpnlis=[] str=''
arith_op="+-*/%" # '(' ')' [0-9]+
评论0
最新资源