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

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

?? gen-test.pas

?? 編譯原理實驗 完整的
?? PAS
字號:
program EL(input,output);



label
   99;

const
   norw=13;
   txmax=100;
   nmax=14;
   al=10;
   amax=2047;
   levmax=3;
   cxmax=200;

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,WRITESYM,READSYM,DOSYM,CALLSYM,
           CONSTSYM,VARSYM,PROCSYM);
   alfa=packed array [1..al] of char;
   object0=(constant,variable,prosedure);
   symset=set of symbol;
   fct=(lit,opr,lod,sto,cal,int,jmp,jpc,red,wrt);
   instruction=packed record
                        f:fct;
                        l:0..levmax;
                        a:0..amax;
                      end;
var
   listswitch:boolean;
   ch:char;
   sym:symbol;
   id:alfa;
   num:integer;
   ii:integer;
   cc:integer;
   ll:integer;
   kk:integer;
   cx:integer;
   err:integer;
   line:array [0..cxmax] of char;
   a:alfa;
   fname:alfa;
   code:array [0..cxmax] of instruction;
   word:array [1..norw] of alfa;
   wsym:array [1..norw] of symbol;
   ssym:array [char] of symbol;
   mnemonic:array [fct] of
             packed array[1..5] of char;
   declbegsys,statbegsys,facbegsys:symset;
   table:array [0..txmax] of
      record name:alfa;
             case kind:object0 of
             constant:(val:integer);
             variable,prosedure:(level,adr:integer)
      end;
   fin:text;
   sfile:string;

procedure error(n: integer);
begin  writeln('****',' ': cc-1,'^',n:2);  err:=err+1
end;{error}

procedure getsym;
   var i,j,k:integer;

   procedure getch;
   begin if cc=ll then
     begin if eof(fin) then
              begin writeln('program incomplete');
                 close(fin);
                 exit;
              end;
           ll:=0;cc:=0;write(cx:4,' ');
           while not eoln(fin) do
              begin ll:=ll+1;  read(fin,ch); write(ch);
                line[ll]:=ch
              end;
           writeln;readln(fin);
           ll:=ll+1;line[ll]:=' '
     end;
     cc:=cc+1;ch:=line[cc]
   end;{getch}

begin
   while ch=' ' do getch;
   if ch in ['a'..'z'] then
   begin
      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
      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 if ch='>' then
      begin sym:=neq; 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 gen(x: fct;y,z: integer);
begin if cx>cxmax then
         begin writeln('program too long');
             close(fin);
             exit;
         end;
      with code[cx] do
        begin f:=x;  l:=y;  a:=z
        end;
      cx:=cx+1
end;{gen}

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}

begin{main}
     writeln('please input source program file name:');
     readln(sfile);
     assign(fin,sfile);
     reset(fin);
     for ch:='A' to ';' 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]:='procefure ';
     word [9]:='read      ';  word[10]:='then      ';
     word[11]:='var       ';  word[12]:='while     ';
     word[13]:='write     ';

     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]:= readsym;  wsym[10]:= thensym;
     wsym[11]:= varsym;   wsym[12]:= whilesym;
     wsym[13]:= writesym;
     ssym ['+']:=plus;    ssym['-']:=minus;
     ssym ['*']:=times;   ssym['/']:=slash;
     ssym ['(']:=lparen;  ssym[')']:=rparen;
     ssym ['=']:=eql;     ssym[',']:=comma;
     ssym ['.']:=period;  ssym['<']:=lss;
     ssym ['>']:=gtr;     ssym[';']:=semicolon;

     mnemonic[lit]:='LIT  '; mnemonic[opr]:='OPR  ';
     mnemonic[lod]:='LOD  '; mnemonic[sto]:='STO  ';
     mnemonic[cal]:='CAL  '; mnemonic[int]:='INT  ';
     mnemonic[jmp]:='JMP  '; mnemonic[jpc]:='JPC  ';
     mnemonic[red]:='RED  '; mnemonic[wrt]:='WRT  ';

     declbegsys :=[constsym,  varsym,  procsym];
     statbegsys :=[beginsym, callsym,    ifsym,   whilesym];
     facbegsys  :=[   ident,  number,   lparen];
     err:=0;

     cc:=0;  cx:=0;  ll:=0;  ch:=' ';  kk:=al;  getsym;
     {block(0,0,[period] +declbegsys+statbegsys); }
     if sym <> period then error(9);
     if err=0 then {interpret}
              else write('ERRORS IN EL PROGRAM');
     writeln;
     close(fin)
end.

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产一区二区三区久久悠悠色av| 国产sm精品调教视频网站| 国产一区二区在线电影| 色综合久久综合| 欧美激情在线免费观看| 日韩va亚洲va欧美va久久| www.av精品| 国产欧美日韩三级| 久久国产精品一区二区| 欧美日本高清视频在线观看| 中文字幕在线观看不卡| 精品一区二区综合| 制服丝袜亚洲网站| 偷拍日韩校园综合在线| 欧美亚一区二区| 亚洲欧美激情小说另类| 高清久久久久久| 国产人成一区二区三区影院| 麻豆国产精品官网| 欧美一级欧美三级| 美女在线一区二区| 9191国产精品| 日韩电影免费在线| 日韩一区和二区| 免费国产亚洲视频| 欧美xxxx老人做受| 老汉av免费一区二区三区| 91精品国产综合久久久久久漫画| 亚洲1区2区3区4区| 欧美日韩国产高清一区二区三区| 亚洲欧美激情视频在线观看一区二区三区 | 国产精品第一页第二页第三页| 经典三级一区二区| 久久久无码精品亚洲日韩按摩| 国产一区在线精品| 欧美激情一区在线| 不卡一二三区首页| 亚洲欧美日韩一区二区| 在线观看亚洲专区| 亚洲成av人**亚洲成av**| 777午夜精品免费视频| 无码av中文一区二区三区桃花岛| 91.xcao| 精品亚洲成av人在线观看| 久久婷婷综合激情| 成人av在线播放网址| 亚洲女同一区二区| 欧美三级韩国三级日本三斤| 日韩精品成人一区二区三区| 56国语精品自产拍在线观看| 免费观看一级欧美片| 国产拍欧美日韩视频二区| av高清久久久| 日韩在线观看一区二区| 精品国产乱码久久久久久免费| 国产成人综合网站| 亚洲乱码中文字幕综合| 91精品婷婷国产综合久久| 国产精品一二三区在线| 亚洲欧洲中文日韩久久av乱码| 欧美视频第二页| 久久99精品久久久久久动态图| 国产精品素人视频| 欧美日韩国产精品成人| 国产精品77777| 亚洲国产成人高清精品| 久久夜色精品国产欧美乱极品| 99精品视频在线播放观看| 天天亚洲美女在线视频| 国产精品毛片无遮挡高清| 欧美电影在哪看比较好| 成人三级伦理片| 婷婷中文字幕一区三区| 中文子幕无线码一区tr| 制服丝袜av成人在线看| 国产精品中文字幕一区二区三区| 一区二区三区在线看| 欧美精品一区二区三区蜜桃| 色综合久久久网| 精油按摩中文字幕久久| 午夜国产精品一区| 国产精品国产三级国产aⅴ入口| 91精品在线观看入口| 色av一区二区| 成人高清av在线| 国产一区三区三区| 日韩成人av影视| 一二三区精品福利视频| 国产免费久久精品| 久久综合九色综合97_久久久| 欧洲在线/亚洲| 99久久精品国产精品久久| 国产一区二区主播在线| 麻豆一区二区99久久久久| 亚洲成人免费电影| 亚洲乱码中文字幕| 国产精品国产三级国产有无不卡| 欧美mv日韩mv国产网站app| 欧美三区免费完整视频在线观看| av在线综合网| fc2成人免费人成在线观看播放| 国内成+人亚洲+欧美+综合在线| 日韩精品电影在线观看| 日韩中文字幕亚洲一区二区va在线| 综合久久久久久| 中文字幕电影一区| 三级欧美在线一区| 一区二区三区四区不卡在线| 中文字幕制服丝袜一区二区三区 | 久久亚洲免费视频| 日韩欧美一区中文| 日韩亚洲欧美一区二区三区| 欧美日韩国产综合久久 | 日韩精品一区二区三区三区免费| 91蝌蚪porny九色| aa级大片欧美| 一道本成人在线| 在线这里只有精品| 欧美色综合网站| 欧美一区二区三区在线电影| 欧美精品在线一区二区| 欧美精品一二三区| 日韩欧美一区二区不卡| 精品国产电影一区二区| 久久嫩草精品久久久久| 国产精品美日韩| 亚洲视频精选在线| 一区二区三区精品在线观看| 亚洲午夜精品在线| 日本成人在线网站| 国产老肥熟一区二区三区| 国产91精品免费| 99re成人精品视频| 欧美三级在线播放| 欧美成人女星排行榜| 国产日韩欧美精品在线| 亚洲人成网站色在线观看 | 精品一区二区久久久| 精品午夜久久福利影院| 国产一区二区福利| 91久久精品午夜一区二区| 欧美亚洲图片小说| 精品国偷自产国产一区| 国产精品久久久久一区二区三区 | 国产精品麻豆视频| 亚洲综合一二三区| 久久精品国产亚洲高清剧情介绍| 国产a视频精品免费观看| 色偷偷久久人人79超碰人人澡| 欧美精选午夜久久久乱码6080| 精品久久五月天| 亚洲精品自拍动漫在线| 看片网站欧美日韩| 91小视频免费看| 日韩欧美中文字幕制服| 亚洲色图自拍偷拍美腿丝袜制服诱惑麻豆| 亚洲成人精品影院| 国产91精品一区二区| 欧美精品国产精品| 一区在线播放视频| 麻豆一区二区三| 在线观看国产精品网站| 久久精品视频一区| 日韩国产精品久久| 色综合久久88色综合天天6| 日韩精品中午字幕| 亚洲成人在线免费| 成人h动漫精品一区二区| 337p亚洲精品色噜噜噜| 亚洲丝袜自拍清纯另类| 激情综合五月婷婷| 中文字幕av一区二区三区高 | 国模一区二区三区白浆| 欧美日韩精品一区二区三区| 中文欧美字幕免费| 久草精品在线观看| 3d动漫精品啪啪1区2区免费| 亚洲三级电影网站| 99在线视频精品| 国产亚洲人成网站| 精品写真视频在线观看| 欧美一区二区三区四区久久| 亚洲福利电影网| 色老头久久综合| 综合在线观看色| 成人短视频下载| 欧美极品美女视频| 国产老肥熟一区二区三区| 精品国产免费久久| 精品中文字幕一区二区小辣椒 | 久久精品一区二区三区不卡牛牛| 午夜精品一区二区三区免费视频| 色国产综合视频| 亚洲狠狠丁香婷婷综合久久久| 成人激情视频网站| 中文字幕一区二区三区四区| 国产91精品一区二区| 国产精品乱人伦| k8久久久一区二区三区 | 久久久高清一区二区三区|