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

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

?? pl0.c

?? C語言編寫的PLO源代碼
?? C
?? 第 1 頁 / 共 3 頁
字號(hào):
/*
 * PL/0 complier program for win32 platform (implemented in C)
 *
 * The program has been test on Visual C++ 6.0, Visual C++.NET and
 * Visual C++.NET 2003, on Win98, WinNT, Win2000, WinXP and Win2003
 *
 * 使用方法:
 * 運(yùn)行后輸入PL/0源程序文件?
 * 回答是否輸出虛擬機(jī)代碼
 * 回答是否輸出名字表
 * fa.tmp輸出虛擬機(jī)代碼
 * fa1.tmp輸出源文件及其各行對(duì)應(yīng)的首地址
 * fa2.tmp輸出結(jié)?
 * fas.tmp輸出名字表
 */

#include <stdio.h>

#include "pl0.h"
#include "string.h"

/* 解釋執(zhí)行時(shí)使用的棧 */
#define stacksize 500


int main()
{
    bool nxtlev[symnum];

    printf("Input pl/0 file:");
    scanf("%s", fname);     /* 輸入文件名 */

    fin = fopen(fname, "r");

    if (fin)
    {
        printf("List object code?(Y/N)");   /* 是否輸出虛擬機(jī)代碼 */
        scanf("%s", fname);
        listswitch = (fname[0]=='y' || fname[0]=='Y');

        printf("List symbol table?(Y/N)");  /* 是否輸出名字表 */
        scanf("%s", fname);
        tableswitch = (fname[0]=='y' || fname[0]=='Y');

        fa1 = fopen("fa1.tmp", "w");
        fprintf(fa1,"Input pl/0 file?   ");
        fprintf(fa1,"%s\n",fname);

        init();     /* 初始化 */

        err = 0;
        cc = cx = ll = 0;
        ch = ' ';

        if(-1 != getsym())
    	{
            fa = fopen("fa.tmp", "w");
            fas = fopen("fas.tmp", "w");
            addset(nxtlev, declbegsys, statbegsys, symnum);
            nxtlev[period] = true;

            if(-1 == block(0, 0, nxtlev))   /* 調(diào)用編譯程序 */
    		{
                fclose(fa);
                fclose(fa1);
                fclose(fas);
                fclose(fin);
                printf("\n");
                return 0;
    		}
            fclose(fa);
            fclose(fa1);
            fclose(fas);

            if (sym != period)
    		{
                error(9);
    		}

            if (err == 0)
    		{
                fa2 = fopen("fa2.tmp", "w");
                interpret();    /* 調(diào)用解釋執(zhí)行程序 */
                fclose(fa2);
    		}
        	else
    		{
                printf("Errors in pl/0 program");
    		}
    	}

        fclose(fin);
    }
    else
    {
        printf("Can't open file!\n");
    }

    printf("\n");
    return 0;
}

/*
* 初始化
*/
void init()
{
    int i;

    /* 設(shè)置單字符符號(hào) */
    for (i=0; i<=255; i++)
    {
        ssym[i] = nul;
    }
    ssym['+'] = plus;
    ssym['-'] = minus;
    ssym['*'] = times;
    ssym['/'] = slash;
    ssym['('] = lparen;
    ssym[')'] = rparen;
    ssym['='] = eql;
    ssym[','] = comma;
    ssym['.'] = period;
    ssym['#'] = neq;
    ssym[';'] = semicolon;

    /* 設(shè)置保留字名字,按照字母順序,便于折半查找 */
    strcpy(&(word[0][0]), "begin");
    strcpy(&(word[1][0]), "call");
    strcpy(&(word[2][0]), "const");
    strcpy(&(word[3][0]), "do");
    strcpy(&(word[4][0]), "end");
    strcpy(&(word[5][0]), "if");
    strcpy(&(word[6][0]), "odd");
    strcpy(&(word[7][0]), "procedure");
    strcpy(&(word[8][0]), "read");
    strcpy(&(word[9][0]), "then");
    strcpy(&(word[10][0]), "var");
    strcpy(&(word[11][0]), "while");
    strcpy(&(word[12][0]), "write");

    /* 設(shè)置保留字符號(hào) */
    wsym[0] = beginsym;
    wsym[1] = callsym;
    wsym[2] = constsym;
    wsym[3] = dosym;
    wsym[4] = endsym;
    wsym[5] = ifsym;
    wsym[6] = oddsym;
    wsym[7] = procsym;
    wsym[8] = readsym;
    wsym[9] = thensym;
    wsym[10] = varsym;
    wsym[11] = whilesym;
    wsym[12] = writesym;

    /* 設(shè)置指令名稱 */
    strcpy(&(mnemonic[lit][0]), "lit");
    strcpy(&(mnemonic[opr][0]), "opr");
    strcpy(&(mnemonic[lod][0]), "lod");
    strcpy(&(mnemonic[sto][0]), "sto");
    strcpy(&(mnemonic[cal][0]), "cal");
    strcpy(&(mnemonic[inte][0]), "int");
    strcpy(&(mnemonic[jmp][0]), "jmp");
    strcpy(&(mnemonic[jpc][0]), "jpc");

    /* 設(shè)置符號(hào)集 */
    for (i=0; i<symnum; i++)
    {
        declbegsys[i] = false;
        statbegsys[i] = false;
        facbegsys[i] = false;
    }

    /* 設(shè)置聲明開始符號(hào)集 */
    declbegsys[constsym] = true;
    declbegsys[varsym] = true;
    declbegsys[procsym] = true;

    /* 設(shè)置語句開始符號(hào)集 */
    statbegsys[beginsym] = true;
    statbegsys[callsym] = true;
    statbegsys[ifsym] = true;
    statbegsys[whilesym] = true;

    /* 設(shè)置因子開始符號(hào)集 */
    facbegsys[ident] = true;
    facbegsys[number] = true;
    facbegsys[lparen] = true;
}

/*
* 每次讀一行,存入line緩沖區(qū),line被getsym取空后再讀一行
*
* 被函數(shù)getsym調(diào)用。
*/
int getch()
{
    if (cc == ll)
    {
        if (feof(fin))
    	{
            printf("program incomplete");
            return -1;
    	}
        ll=0;
        cc=0;
        printf("%d ", cx);
        fprintf(fa1,"%d ", cx);
        ch = ' ';
        while (ch != 10) //10為換行符
    	{
            if (EOF == fscanf(fin,"%c", &ch))
    		{
                line[ll] = 0;
            	break;
    		}
            printf("%c", ch);
            fprintf(fa1, "%c", ch);
            line[ll] = ch;
        	ll++;
    	}
        printf("\n");
        fprintf(fa1, "\n");
    }
    ch = line[cc];
    cc++;
    return 0;   //0為讀取成功
}

/*
* 詞法分析,獲取一個(gè)符號(hào)
*/
int getsym()
{
    int i,j,k;

    /* the original version lacks "\r", thanks to foolevery */
    while (ch==' ' || ch==10 || ch==13 || ch==9)  /* 忽略空格、換行、回車和TAB */
    {
        getchdo;
    }
    if (ch>='a' && ch<='z')
    {           /* 名字或保留字以a..z開頭 */
        k = 0;
        do {
            if(k<al)
    		{
                a[k] = ch;
        		k++;
    		}
            getchdo;
        } while (ch>='a' && ch<='z' || ch>='0' && ch<='9');
        a[k] = 0;
        strcpy(id, a);
        i = 0;
        j = norw-1;
        do {    /* 搜索當(dāng)前符號(hào)是否為保留字 */
            k = (i+j)/2;
			if (strcmp(id,word[k]) == 0) 
			{
				sym = wsym[k];
				break; 
			}
            if (strcmp(id,word[k]) < 0)
                j = k - 1;    	
            else
                i = k + 1;    		
        } while (i <= j);
        if ( i > j)
    	{
            sym = ident; /* 搜索失敗則,是名字或數(shù)字 */
    	}
    }
    else
    {
        if (ch>='0' && ch<='9')
        {           /* 檢測是否為數(shù)字:以0..9開頭 */
            k = 0;
            num = 0;
            sym = number;
        	do {
                num = 10*num + ch - '0';
        		k++;
            	getchdo;
            } while (ch>='0' && ch<='9'); /* 獲取數(shù)字的值 */
        	k--;
            if (k > nmax)
    		{
                error(30);
    		}
    	}
        else
    	{
            if (ch == ':')      /* 檢測賦值符號(hào) */
    		{
            	getchdo;
                if (ch == '=')
        		{
                    sym = becomes;
                	getchdo;
        		}
        		else
        		{
                    sym = nul;  /* 不能識(shí)別的符號(hào) */
        		}
    		}
        	else
    		{
                if (ch == '<')      /* 檢測小于或小于等于符號(hào) */
        		{
                	getchdo;
                    if (ch == '=')
        			{
                		sym = leq;
                		getchdo;
        			}
            		else
        			{
                		sym = lss;
        			}
        		}
        		else
        		{
                    if (ch=='>')        /* 檢測大于或大于等于符號(hào) */
        			{
                		getchdo;
                    	if (ch == '=')
        				{
                    		sym = geq;
                			getchdo;
        				}
            			else
        				{
                    		sym = gtr;
        				}
        			}
            		else
        			{
                        sym = ssym[ch];     /* 當(dāng)符號(hào)不滿足上述條件時(shí),全部按照單字符符號(hào)處理 */
                		if (sym != period)
        				{
                			getchdo;
        				}
        			}
        		}
    		}
    	}
    }
    return 0;
}

/*
* 查找名字的位置.
* 找到則返回在名字表中的位置,否則返回0.
*
* idt:    要查找的名字
* tx:     當(dāng)前名字表尾指針
*/
int position(char* idt, int tx)
{
    int i;
    strcpy(table[0].name, idt);
    i = tx;
    while (strcmp(table[i].name, idt) != 0)
    {
        i--;
    }
    return i;
}

/*
* 在名字表中加入一項(xiàng)
*
* k:      名字種類constant, variable, procedur
* ptx:    名字表尾指針的指針,為了可以改變名字表尾指針的值
* lev:    名字所在的層次,,以后所有的lev都是這樣
* pdx:    dx為當(dāng)前應(yīng)分配的變量的相對(duì)地址,分配后要增加1
*/
void enter(enum object k, int* ptx, int lev, int* pdx)
{
    (*ptx)++;
    strcpy(table[(*ptx)].name, id); /* 全局變量id中已存有當(dāng)前名字的名字 */
    table[(*ptx)].kind = k;
    switch (k)
    {
    case constant:  /* 常量名字 */
        if (num > amax)
    	{
            error(31);  /* 數(shù)越界 */
            num = 0;
    	}
        table[(*ptx)].val = num;
        break;
    case variable:  /* 變量名字 */
        table[(*ptx)].level = lev;
        table[(*ptx)].adr = (*pdx);
        (*pdx)++;
        break;
    case procedur:  /* 過程名字 */
        table[(*ptx)].level = lev;
        break;
    }
}

/*
* 用數(shù)組實(shí)現(xiàn)集合的集合運(yùn)算
*/
int inset(int e, bool* s)
{
    return s[e];
}

int addset(bool* sr, bool* s1, bool* s2, int n)
{
    int i;
    for (i=0; i<n; i++)
    {
        sr[i] = s1[i]||s2[i];
    }
    return 0;
}

int subset(bool* sr, bool* s1, bool* s2, int n)
{
    int i;
    for (i=0; i<n; i++)
    {
        sr[i] = s1[i]&&(!s2[i]);
    }
    return 0;
}

int mulset(bool* sr, bool* s1, bool* s2, int n)
{
    int i;
    for (i=0; i<n; i++)
    {
        sr[i] = s1[i]&&s2[i];
    }
    return 0;
}

/*
* 測試當(dāng)前符號(hào)是否合法
*
* 在某一部分(如一條語句,一個(gè)表達(dá)式)將要結(jié)束時(shí)時(shí)我們希望下一個(gè)符號(hào)屬于某集合

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
蜜桃一区二区三区在线观看| 欧美午夜精品免费| 国产精品自在欧美一区| 亚洲精品国产一区二区精华液 | 欧美国产丝袜视频| 久久综合狠狠综合久久激情| 精品福利一二区| 欧美mv日韩mv| 久久网站热最新地址| 2021久久国产精品不只是精品| 日韩欧美电影一二三| 欧美一级高清大全免费观看| 6080午夜不卡| 婷婷一区二区三区| 色菇凉天天综合网| 在线这里只有精品| 欧美三级电影精品| 欧美精品三级在线观看| 精品视频一区 二区 三区| 色综合一区二区| 欧美亚洲国产一区二区三区va| 欧美三级电影网站| 日韩午夜精品电影| 久久久久久久久岛国免费| 国产精品女主播av| 一区二区三区在线视频免费| 污片在线观看一区二区| 久久91精品国产91久久小草 | 国产成a人无v码亚洲福利| 懂色av中文一区二区三区| 91丨porny丨户外露出| 欧美亚洲动漫精品| 日韩一级黄色大片| 国产精品青草综合久久久久99| 亚洲伦理在线精品| 日韩1区2区3区| 国产成人在线影院| 在线一区二区三区四区| 91精品福利在线一区二区三区 | 捆绑调教美女网站视频一区| 国产成人精品免费一区二区| 91碰在线视频| 欧美一级在线视频| 国产欧美日韩三级| 亚洲一区二区三区国产| 精品一二三四区| 99热精品国产| 制服丝袜亚洲播放| 国产精品久久久久婷婷| 日韩福利电影在线| 成人午夜在线视频| 69久久夜色精品国产69蝌蚪网| 国产欧美在线观看一区| 亚洲成av人片| 成人爽a毛片一区二区免费| 欧美在线综合视频| 欧美激情一区二区三区不卡| 亚洲成人av一区二区三区| 国产成人免费视频网站高清观看视频| 91成人免费在线| 国产清纯美女被跳蛋高潮一区二区久久w| 亚洲一区二区视频| 国产成人免费高清| 91精品国产一区二区| 亚洲欧美另类久久久精品2019| 久久精品国内一区二区三区| 日本久久电影网| 久久精品亚洲一区二区三区浴池| 午夜欧美视频在线观看| 波多野结衣欧美| 精品女同一区二区| 爽好多水快深点欧美视频| 91视视频在线观看入口直接观看www | 欧美日韩国产高清一区二区三区| 国产精品久久夜| 久久99久久久久久久久久久| 欧美中文字幕亚洲一区二区va在线| 国产欧美日韩综合精品一区二区| 免费成人av在线| 1000部国产精品成人观看| 国产真实乱子伦精品视频| 欧美高清dvd| 亚洲精品成人在线| bt欧美亚洲午夜电影天堂| 2017欧美狠狠色| 免费成人结看片| 欧美精品在线一区二区三区| 国产精品久久久久久妇女6080| 国产一区二区免费在线| 欧美成人一区二区三区片免费| 亚洲1区2区3区4区| 欧美性xxxxxxxx| 伊人性伊人情综合网| 97精品视频在线观看自产线路二| 国产午夜精品福利| 国产一区二区在线观看视频| 欧美一区二区免费视频| 天天综合网天天综合色| 欧美性受xxxx黑人xyx性爽| 国产精品第13页| 成人av在线一区二区三区| 欧美国产综合一区二区| 国产电影一区在线| 国产亚洲精品久| 国产精品原创巨作av| 欧美变态口味重另类| 卡一卡二国产精品 | 免费看欧美女人艹b| 91精品国产综合久久福利软件 | 在线一区二区视频| 亚洲一本大道在线| 欧美中文字幕久久| 午夜影院久久久| 51精品久久久久久久蜜臀| 奇米一区二区三区| 欧美精品一区二区三区蜜臀| 国产呦萝稀缺另类资源| 国产亚洲成aⅴ人片在线观看 | 色综合久久综合网97色综合 | 久久99热国产| 久久久久久久久久久久久女国产乱 | 亚洲欧美综合色| 日本久久电影网| 天天影视网天天综合色在线播放| 91精品国产综合久久久久久久久久 | 综合久久久久久| 欧美日韩中文字幕一区二区| 日韩中文字幕区一区有砖一区| 欧美一区二区免费视频| 国产综合成人久久大片91| 亚洲国产精品99久久久久久久久| aaa亚洲精品| 亚洲va在线va天堂| 精品国产电影一区二区| 成人免费看片app下载| 一本大道综合伊人精品热热| 亚洲1区2区3区4区| 26uuu国产日韩综合| 99re热视频精品| 日韩成人免费电影| 国产日韩精品一区| 在线观看av不卡| 久久超碰97中文字幕| 中文字幕不卡的av| 欧美群妇大交群中文字幕| 国产一区二区h| 一区二区三区精品在线| 欧美成人激情免费网| 波多野结衣一区二区三区 | 99久久久久久99| 亚洲h精品动漫在线观看| 久久综合久久99| 在线观看亚洲精品| 老色鬼精品视频在线观看播放| 国产精品传媒在线| 日韩天堂在线观看| av电影在线观看不卡| 日本美女视频一区二区| 日韩一区中文字幕| 日韩色视频在线观看| 99精品热视频| 韩国女主播成人在线| 亚洲一区二区三区美女| 国产无遮挡一区二区三区毛片日本| 欧美亚洲精品一区| 国产成人精品一区二| 天堂久久一区二区三区| 国产精品高潮久久久久无| 在线不卡免费av| 91热门视频在线观看| 国产成人在线影院| 日韩精品一区第一页| 亚洲天堂免费看| 国产亚洲一区字幕| 日韩欧美视频一区| 欧美日韩小视频| 91麻豆产精品久久久久久 | 欧美区在线观看| 97成人超碰视| 国产成人丝袜美腿| 美女精品一区二区| 午夜精品福利一区二区三区蜜桃| |精品福利一区二区三区| 久久久久久电影| 日韩一区二区三区在线观看| 在线看日韩精品电影| av亚洲精华国产精华| 国产成人一区在线| 久久精品国产成人一区二区三区 | 成人精品亚洲人成在线| 久久狠狠亚洲综合| 日精品一区二区| 亚洲123区在线观看| 亚洲男同性视频| 亚洲欧洲www| 中文字幕中文字幕在线一区| 久久久激情视频| 国产亚洲欧美中文| 国产午夜精品理论片a级大结局| 欧美大度的电影原声|