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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? program5.pas

?? PLO的此法分析語法分析
?? PAS
字號:
program PL0(input,output);
(* PL/0 compiler with syntax error recovery *)
const norw = 11;        (* no. of reserved words *)
  txmax = 100;          (* length of identifier table *)
  nmax = 14;            (* max. no of digits in numbers *)
  al = 10;              (* length of identifiers *)
  chsetsize = 128;      (* for ASCII character set *)
  maxerr = 30;          (* max. no. of errors *)
type symbol =
  (nul,ident,number,plus,minus,times,slash,oddsym,
   eql,neq,lss,leq,gtr,geq,lparen,rparen,comma,semicolon,
   period,becomes,beginsym,endsym,ifsym,thensym,
   whilesym,dosym,callsym,constsym,varsym,procsym);
  alfa = packed array [1..al] of char;
  objekt = (constant,variable,prozedure);
  symset = set of symbol;
var ch:char;            (* last character read *)
  sym: symbol;          (* last symbol read *)
  id: alfa;             (* last identifier read *)
  num: integer;         (* last number read *)
  cc: integer;          (* character count *)
  ll: integer;          (* line length *)
  kk,err: integer;
  line: array[1..81] of char;
  a: alfa;
  word: array[1..norw] of alfa;
  wsym: array[1..norw] of symbol;
  ssym: array [char] of symbol;
  declbegsys, statbegsys, facbegsys: symset;
  table: array [0..txmax] of
                record name: alfa;
                       kind: objekt;
                end;
  inf,outf: text;

procedure error(n: integer);
begin writeln(' ':cc-1,'^',n:2);
  writeln(outf,' ':cc-1,'^',n:2);
  err := err + 1; if err > maxerr then halt
end(* error *);

procedure getsym;
  var i,j,k:integer;
  procedure getch;
  begin if cc = ll then
    begin if eof(inf) then
        begin write('program incomplete'); halt
        end;
      ll:= 0; cc:= 0;
      while not eoln(inf) do
        begin ll:=ll+1; read(inf,ch); write(ch); 
write(outf,ch); line[ll]:= ch
        end;
      writeln; writeln(outf); ll:=ll+1; readln(inf); line[ll]:=' '
    end;
    cc:=cc+1; ch:=line[cc]
  end(* getch *);

(* getsym *)
begin (* getsym *)
  while ch=' ' do getch;
  if ch in ['a'..'z'] then
  begin (* identifier or reserved word *) k:=0;
    repeat if k < al then
      begin k:=k+1; a[k]:=ch
      end;
      getch
    until not (ch in ['a'..'z','0'..'9']);
    if k>=kk then kk:=k else
      repeat a[kk]:=' '; kk:=kk-1
      until kk=k;
    id:=a; i:=1; j:=norw;
    repeat k:=(i+j)div 2;
      if id<=word[k] then j:=k-1;
      if id>=word[k] then i:=k+1
    until i>j;
    if i-1>j then sym:=wsym[k] else sym:=ident
  end else
  if ch in ['0'..'9'] then
  begin (* number *) k:=0; num:=0; sym:=number;
    repeat num:=10*num+(ord(ch)-ord('0'));
      k:=k+1; getch
    until not (ch in ['0'..'9']);
    if k> nmax then error(30)
  end else
  if ch=':' then
  begin getch;
    if ch='=' then
    begin sym:=becomes; getch
    end else sym:=nul;
  end else
  if ch='<' then
  begin getch;
    if ch='=' then
    begin sym:=leq; getch
    end else sym:=lss
  end else
  if ch='>' then
  begin getch;
    if ch='=' then
    begin sym:=geq; getch
    end else sym:=gtr
  end else
  begin sym:=ssym[ch]; getch
  end
end(* getsym *);

procedure test(s1,s2:symset; n:integer);
begin if not(sym in s1) then
  begin error(n); s1:=s1 +s2;
    while not (sym in s1) do getsym
  end
end(*test*);

procedure block(tx: integer; fsys: symset);
  procedure enter(k:objekt);
  begin (*enter object into table*)
    tx:=tx+1;
    with table[tx] do
      begin name:=id;
            kind:=k;
      end
  end(*enter*);
  function position(id:alfa):integer;
    var i:integer;
  begin(* find identifier id in table *)
    table[0].name:=id; i:=tx;
    while table[i].name<>id do i:=i-1;
    position:=i
  end(* position *);
  procedure constdeclaration;
  begin if sym=ident then
    begin getsym;
        if sym in [eql,becomes] then
        begin if sym = becomes then error(1);
         getsym;
            if sym=number then
                begin enter(constant); getsym
          end
        else error(2)
      end else error(3)
    end else error(4)
  end (* constdeclaration *);
  procedure vardeclaration;
  begin if sym=ident then
        begin enter(variable); getsym
        end else error(4)
  end(* vardeclaration *);
  procedure statement(fsys: symset);
    var i:integer;
    procedure expression(fsys: symset);
      procedure term(fsys: symset);
        procedure factor(fsys: symset);
          var i:integer;
        begin test(facbegsys,fsys,24); 
          while sym in facbegsys do
          begin
          if sym=ident then
          begin i:=position(id);
            if i=0 then error(11) else
            if table[i].kind = prozedure then error(21);
            getsym
          end else
          if sym=number then
          begin getsym
          end else
          if sym=lparen then
          begin getsym; expression([rparen]+fsys);
            if sym=rparen then getsym else error(22)
          end;
          test(fsys,[lparen],23)
        end
      end(*factor*);
      begin(* term *) factor(fsys+[times,slash]);
        while sym in [times,slash] do
          begin getsym; factor(fsys+[times,slash])
          end
      end(* term *);
    begin (* expression *)
      if sym in [plus,minus] then
        begin getsym; term(fsys+[plus,minus]);
        end else term(fsys+[plus,minus]);
      while sym in [plus,minus] do
        begin getsym; term(fsys+[plus,minus]);
        end
    end(*expression*);
    procedure condition(fsys: symset);
    begin
      if sym=oddsym then
      begin getsym; expression(fsys);
      end else
      begin expression([eql,neq,lss,gtr,leq,geq]+fsys);
        if not(sym in [eql,neq,lss,leq,gtr,geq]) then
          error(20) else
        begin getsym; expression(fsys);
        end
      end
    end(*condition*);
  begin(*statement*)
    if sym=ident then
    begin i:=position(id);
      if i=0 then error(11) else
      if table[i].kind<>variable then error(12);
      getsym; if sym=becomes then getsym else error(13);
      expression(fsys);
    end else
    if sym=callsym then
    begin getsym;
      if sym<>ident then error(14) else
        begin i:=position(id);
          if i=0 then error(11) else
          if table[i].kind <> prozedure then error(15);
          getsym
        end
    end else
    if sym=ifsym then
    begin getsym; condition([thensym,dosym]+fsys);
      if sym=thensym then getsym else error(16);
      statement(fsys);
    end else
    if sym=beginsym then
    begin getsym; statement([semicolon,endsym]+fsys);
      while sym in [semicolon]+statbegsys do
      begin
        if sym = semicolon then getsym else error(10);
        statement([semicolon,endsym]+fsys)
      end;
      if sym=endsym then getsym else error(17)
    end else
    if sym=whilesym then
    begin getsym; condition([dosym]+fsys);
      if sym=dosym then getsym else error(18);
      statement(fsys);
    end;
    test(fsys,[],19)
  end(*statement*);
begin(*block*)
  repeat
    if sym=constsym then
    begin getsym;
      repeat constdeclaration;
        while sym=comma do
          begin getsym; constdeclaration
          end;
        if sym=semicolon then getsym else error(5)
      until sym <> ident
    end;
    if sym=varsym then
    begin getsym;
      repeat vardeclaration;
        while sym=comma do
          begin getsym; vardeclaration
          end;
        if sym=semicolon then getsym else error(5)
      until sym <> ident;
    end;
    while sym=procsym do
    begin getsym;
      if sym=ident then
        begin enter(prozedure); getsym
        end
      else error(4);
      if sym=semicolon then getsym else error(5);
      block(tx, [semicolon]+fsys);
      if sym=semicolon then
        begin  getsym; test(statbegsys+[ident,procsym],fsys,6)
        end
       else error(5)
    end;
    test(statbegsys+[ident],declbegsys,7)
   until not (sym in declbegsys);
  statement([semicolon,endsym]+fsys);
  test(fsys,[],8);
end(*block*);
begin(* main program *)
  assign(inf,'c:\testin.pl0');
  assign(outf,'c:\testout.txt');
  reset(inf);
  rewrite(outf);
  for ch:=chr(0) to chr(chsetsize-1) do ssym[ch]:=nul;
  word[ 1]:='begin     '; word[ 2]:='call      ';
  word[ 3]:='const     '; word[ 4]:='do        ';
  word[ 5]:='end       '; word[ 6]:='if        ';
  word[ 7]:='odd       '; word[ 8]:='procedure ';
  word[ 9]:='then      '; word[10]:='var       ';
  word[11]:='while     ';
  wsym[ 1]:=beginsym; wsym[ 2]:=callsym;
  wsym[ 3]:=constsym; wsym[ 4]:=dosym;
  wsym[ 5]:=endsym;   wsym[ 6]:=ifsym;
  wsym[ 7]:=oddsym;   wsym[ 8]:=procsym;
  wsym[ 9]:=thensym;  wsym[10]:=varsym;
  wsym[11]:=whilesym;
  ssym['+']:=plus;   ssym['-']:=minus;
  ssym['*']:=times;  ssym['/']:=slash;
  ssym['(']:=lparen; ssym[')']:=rparen;
  ssym['=']:=eql;    ssym[',']:=comma;
  ssym['.']:=period; ssym['#']:=neq;
  ssym['<']:=lss;    ssym['>']:=gtr;
  ssym[';']:=semicolon;
  declbegsys:=[constsym,varsym,procsym];
  statbegsys:=[beginsym,callsym,ifsym,whilesym];
  facbegsys:=[ident,number,lparen];
  err:=0;
  cc:=0; ll:=0; ch:=' '; kk:=al; getsym;
  block(0,[period]+declbegsys+statbegsys);
  if sym<>period then error(9);
  writeln;
  writeln(outf);
  close(outf);
end. 

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一级日韩不卡播放免费| 91精品国产乱码| 成人一级片在线观看| 国产老女人精品毛片久久| 国内精品在线播放| 国产成人综合网| 欧美三级在线看| 欧美精品色一区二区三区| 7777女厕盗摄久久久| 日韩一二在线观看| 精品国产乱码久久久久久闺蜜| 91精品久久久久久久91蜜桃| 日韩免费高清视频| 久久在线观看免费| 国产精品国产精品国产专区不片| 中文字幕亚洲一区二区av在线 | 亚洲欧洲中文日韩久久av乱码| 国产日韩欧美a| 中文字幕av一区二区三区| 国产精品美女久久久久av爽李琼| 欧美国产综合一区二区| 亚洲精品一二三区| 日日噜噜夜夜狠狠视频欧美人 | 一区二区三区高清| 有码一区二区三区| 日本亚洲三级在线| 国产剧情一区在线| 91美女在线看| 欧美一区二区日韩一区二区| 国产日韩三级在线| 亚洲视频你懂的| 日韩精品午夜视频| 国产制服丝袜一区| 91久久国产最好的精华液| 欧美另类一区二区三区| 久久亚洲精品国产精品紫薇| 亚洲图片另类小说| 日本vs亚洲vs韩国一区三区二区| 久久精品这里都是精品| 中文字幕国产精品一区二区| 亚洲激情五月婷婷| 精品伊人久久久久7777人| caoporn国产精品| 51久久夜色精品国产麻豆| 久久综合九色综合欧美亚洲| 亚洲品质自拍视频网站| 久久精品国产免费看久久精品| 777a∨成人精品桃花网| 国产三级一区二区三区| 亚洲一区在线免费观看| 国产高清一区日本| 欧美视频一区二区三区在线观看 | 国产精品免费人成网站| 亚洲第一搞黄网站| 床上的激情91.| 欧美一卡二卡在线观看| 亚洲精品国产品国语在线app| 蜜臀av性久久久久蜜臀aⅴ四虎| 风间由美一区二区av101| 欧美日本在线一区| 国产精品免费视频网站| 久久99国内精品| 欧美三级日韩在线| 国产精品久久久久久久久免费丝袜| 欧美成人激情免费网| 毛片av一区二区三区| 成人听书哪个软件好| 欧美精品三级在线观看| 亚洲欧美自拍偷拍色图| 免费高清不卡av| 91国内精品野花午夜精品| 欧美国产精品劲爆| 麻豆精品一区二区av白丝在线| 欧美又粗又大又爽| 国产精品无遮挡| 韩国在线一区二区| 欧美一区二区视频在线观看2020| 亚洲特级片在线| 国内成人免费视频| 欧美一级欧美三级在线观看| 亚洲欧美综合另类在线卡通| 国产成人av电影在线播放| 日韩欧美高清一区| 天堂精品中文字幕在线| 91福利在线免费观看| 亚洲天堂福利av| 99热在这里有精品免费| 国产婷婷色一区二区三区四区| 一本色道久久综合狠狠躁的推荐| 精品国内二区三区| 美女一区二区在线观看| 欧美精选一区二区| 亚洲午夜视频在线观看| 日本大香伊一区二区三区| 国产精品欧美一级免费| 国产成a人亚洲| 欧美国产精品一区二区三区| 国产一区二区免费在线| 日韩欧美亚洲国产精品字幕久久久 | 国产激情91久久精品导航| 精品久久久久99| 韩国一区二区三区| 久久综合99re88久久爱| 国产一区二区h| 国产欧美一区二区精品性色超碰| 韩国av一区二区| 久久久久久久久久久久电影| 国产精品综合网| 26uuu欧美| 国产成人福利片| 亚洲国产精品ⅴa在线观看| 成人国产一区二区三区精品| 成人欧美一区二区三区白人| 99久久久精品| 一区二区三区四区在线| 91极品美女在线| 性欧美疯狂xxxxbbbb| 欧美精选一区二区| 精久久久久久久久久久| 精品国产污网站| 国产不卡视频一区二区三区| **欧美大码日韩| 在线日韩国产精品| 亚洲成人在线免费| 日韩一区二区三区精品视频| 国产乱色国产精品免费视频| 国产精品美女视频| 日本电影亚洲天堂一区| 亚洲18女电影在线观看| 日韩美女视频在线| 成人美女在线视频| 亚洲一区二区四区蜜桃| 91精品国产综合久久蜜臀 | 91麻豆国产在线观看| 亚洲一区二区视频| 欧美岛国在线观看| 国产69精品久久久久777| 亚洲精品欧美在线| 日韩一区二区三区视频| 成人h精品动漫一区二区三区| 亚洲综合色区另类av| 日韩欧美一区二区三区在线| 久久免费精品国产久精品久久久久| 国产69精品久久久久777| 亚洲三级在线免费观看| 欧美放荡的少妇| 狠狠色狠狠色综合日日91app| 国产精品久久久久国产精品日日| 欧美三级电影在线观看| 国产美女在线精品| 亚洲一区二区精品视频| 欧美变态tickling挠脚心| 97精品国产露脸对白| 日本亚洲视频在线| 亚洲欧洲韩国日本视频| 在线综合+亚洲+欧美中文字幕| 国产成人精品免费网站| 亚洲va国产天堂va久久en| 中文字幕av资源一区| 欧美高清你懂得| 成人一级片网址| 久久国产精品免费| 亚洲激情一二三区| 日本一区二区免费在线 | 26uuu欧美| 欧美日韩在线免费视频| 粉嫩av一区二区三区在线播放| 亚洲国产wwwccc36天堂| 国产精品私人影院| 欧美岛国在线观看| 欧美三级日韩三级| 99久久99久久久精品齐齐| 国产在线不卡一区| 欧美国产综合色视频| 成人午夜私人影院| 日本伊人精品一区二区三区观看方式| 国产亚洲1区2区3区| 视频一区二区三区在线| 国产精品久久久久久久久免费丝袜 | 国产精品天干天干在观线| 91精品国产福利| 欧美日韩一区不卡| 色婷婷精品久久二区二区蜜臂av | 欧美系列亚洲系列| av激情综合网| 国产精品一区二区久激情瑜伽| 天天综合网 天天综合色| 玉米视频成人免费看| 中文字幕一区二区三区在线观看| 亚洲精品久久嫩草网站秘色| 久久久久久久综合| 日韩一区二区三区视频在线观看 | 亚洲一区二区在线观看视频 | 久久综合综合久久综合| 日韩影院精彩在线| 成人av在线播放网址| 国产盗摄一区二区三区| 国模大尺度一区二区三区| 久久精品国产一区二区| 日韩成人精品在线观看|