#include<iostream>
#include<vector>
#include<utility>//pair
#include<string>
#include<fstream>
#include<algorithm>
#include<cstdlib>
using namespace std;
//用来存储目标文件名
string file_name;
//提取文本文件中的信息。
string GetText();
//获得一个单词符号,从位置i开始查找。
//并且有一个引用参数j,用来返回这个单词最后一个字符在str的位置。
string GetWord(string str,int i,int& j);
//这个函数用来除去字符串中连续的空格和换行
//第一个参数为目标字符串,第二个参数为开始位置
//返回值为连续的空格和换行后的第一个有效字符在字符串的位置
int DeleteNull(string str,int i);
//判断i当前所指的字符是否为一个分界符,是的话返回真,反之假
bool IsBoundary(string str,int i);
//判断i当前所指的字符是否为一个运算符,是的话返回真,反之假
bool IsOperation(string str,int i);
//此函数判断传递的参数是否为关键字,是的话,返回真,反之返回假
bool IsKey(string str);
//此函数将一个pair数组输出到一个文件中
void OutFile(vector<pair<int,string> > v);
//此函数接受一个字符串数组,对它进行词法分析,返回一个pair型数组
vector<pair<int,string> > analyst(vector<string> vec);
int main()
{
cout<<"###########################\n";
cout<<"###欢迎使用词法分析程序####\n";
cout<<"###欢迎使用词法分析程序####\n";
string com1=" ",com2="\n";
string fileline=GetText();
int begin=0,end=0;
vector<string> array;
do//将整个程序断成单词,然后逐个分析单词
{
begin=DeleteNull(fileline,begin);//删除从begin开始的空格
string nowString;
nowString=GetWord(fileline,begin,end);
if(end==-1)//fileline截取完成,跳出
break;
//如果nowString不等于空格且不等于换行,则将nowstring加入array中
if(nowString.compare(com1)&&nowString.compare(com2))
array.push_back(nowString);
- 1
- 2
前往页