zoukankan      html  css  js  c++  java
  • 词法分析

    #include<stdio.h>
    #include<string.h>
    char prog[800],token[20];
    char ch;
    int syn,p,m,sum;
    char *rwtab[6]={"begin","if","then","while","do","end"};
    
    scaner()
    {
    	int n;
    	for(n=0;n<20;n++)
    	m=0;
    	sum=0;
    	ch=prog[p++];
    	while(ch>='a'&&ch<='z')
    	{
    		ch=prog[p++];
    	}
    	if(ch>='a'&&ch<='z'||ch>='0'&&ch<='9')
    	{
    		token[m++]=ch;
    		ch=prog[p++];
    	}
    	syn=10;
    	p--;
    	for(n=0;n<6;n++)//标识符是否为关键词
    	{
    		if(strcmp(token,rwtab[n])==0)
    		{
    			syn=n+1;
    			break;
    		}
    		else if
    		{
    			if(ch>='0'&&ch<='9')
    			{
    				sum=sum*10+(ch-'0');
    				ch=prog[p++];
    			}
    			syn=11;
    			p--;       
    		}
    		else 
    		{
    			switch(ch)
    		{
    			case '<':
    				token[m++]=ch;
    				ch=prog[p++];
    				if(ch='>')
    				{
    					syn=21;
    					token[m++]=ch;
    				}
    				else if(ch=='=')
    				{
    					syn=22;
    					token[m++]=ch;
    				}
    				else
    				{syn=20;
    				p--;
    				}break;
    			case '>':m=0;
    				token[m++]=ch;
    				ch=prog[p++];
    				if(ch=='=')
    				{
    					syn=24;token[m++]=ch;
    				}
    				else
    				{
    					syn=23;p--;
    				}
    				break;
    			case ':':
    				m=0;token[m++]=ch;
    				ch=prog[p++];
    				if(ch=='=')
    				{
    					syn=18;
    					token[m++]=ch;
    				}
    				else
    				{
    					syn=17;
    					p--;
    				}
    				break;
    			case '+':syn=13;token[0]=ch;break;
    			case '-':syn=14;token[0]=ch;break;
    			case '*':syn=15;token[0]=ch;break;
    			case '/':syn=16;token[0]=ch;break;
    			case '=':syn=25;token[0]=ch;break;
    			case ';':syn=26;token[0]=ch;break;
    			case '(':syn=27;token[0]=ch;break;
    		    case ')':syn=28;token[0]=ch;break;
    			case '#':syn=0; token[0]=ch;break;
    			default: syn=-1;token[0]=ch;
    		}
    	}
    
    main()
    {
    	p=0;
    	printf("\n请输入源程序段");
    	do{
    		ch=getchar();
    		prog[p++]=ch;
    	}while(ch!='#');
    	p=0;
    	do{
    		scaner();//读取一个单词符号,类型syn,单词token或sum
    		switch(syn)
    		{
    		case 11:printf("\n(%d,%d)",syn,sum);
    			break;
    		case -1:printf("\n(%s,出错!)",token);
    			break;
    		default:printf("\n(%d,%s)",syn,token);
    		}
    	}while(syn!=0);
    	System("pause");
    }
    
    
    
    					
    				
    

      

  • 相关阅读:
    iOS UI控件7(UITableView)
    iOS UI控件6
    iOS UI控件5-UIPickerView
    iOS UI控件4
    iOS UI控件(3)
    iOS UI控件(2) UITextView
    iOS UI控件(1)
    C# 解决上位机串口接收数据丢失问题
    C# 串口操作系列(3) -- 协议篇,二进制协议数据解析
    如何将Debug文件夹下的资源打包成一个EXE文件直接执行
  • 原文地址:https://www.cnblogs.com/YY0302/p/6025574.html
Copyright © 2011-2022 走看看