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

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

?? fine.c

?? 一個類C詞法分析程序
?? C
字號:
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<malloc.h>
#define MAX 33
#define SIZE 1000
struct node{
 char data[33];
 struct node *next;
 };
struct {
 int ip;
 struct node *link;
 }hash[SIZE];
typedef struct
{
	char b[40];
}string;


char *token[]={"auto","double","int","struct",
		 "break","else","long","switch",
		 "case","enum","register","typedef",
		 "char","extern","return","union",
		 "const","float","short","unsigned",
		 "continue","for","signed","void",
		 "default","goto","sizeof","volatile",
		 "do","if","static","while","main"};

int h(char *p);
int zhifutype(char *p);
void creatHash();
int searchHash(char *p);
void insertHash(char *p);
string zf(FILE *fp);
void display();
void main()
{
	FILE *fp;
	char a[1000];
	string c;
	int i=0;
	if((fp=fopen("1.txt","r"))==NULL)
	{
		printf("can't open the file\n");
	    exit(-1);
	}
    while(!feof(fp))
	  {
		  a[i]=fgetc(fp);
		  i++;
	  }
	  a[i]='\0';
     printf("%s",a);
	fclose(fp);
	creatHash();
   if((fp=fopen("1.txt","r"))==NULL)
   {
		printf("can't open the file\n");
		exit(-1);
   }
   while(!feof(fp))
	{
     c=zf(fp);
     i=searchHash(c.b);
	 if(i=-1)
	 insertHash(c.b);
	}
	display();
   
}

/*************************************/
string  zf(FILE *fp)
{
 string q,p;
 char c,a[100];
 int i=0,fale=0;
 p.b[0]='\0';
 if(!feof(fp))
 {
   q.b[i]=fgetc(fp);
   if(q.b[i]==' '||q.b[i]=='\n')
   {
	   if(feof(fp)) return p;
       else while((c=fgetc(fp))==' '||c=='\n'||c=='\r'||c=='\0');
	   q.b[i]=c;
   }
   switch(q.b[i])
  {
  case '#':case ';':case '?':case '\'':case '"':
  case ':':case '(':case ')':case '[': case ']':
  case '{':case '}':break;
  case '/':if(feof(fp)) return p;
	       else if((c=fgetc(fp))=='*')
		   {   
			   q.b[++i]=c;
			   if(feof(fp)) return p;
			   while(c=fgetc(fp))
			   {
				   if(c=='*')
				     if((c=fgetc(fp))=='/')
					 {
						 fseek(fp,-2,1);
						 break;
					 }
				     else fseek(fp,-1,1);
			   }
			   break;
		   }
	       else if(c=='/')
		   {
			   q.b[++i]=c;
			   fgets(a,99,fp);
			   break;
		   }
		   else {fseek(fp,-1,1);break;}
  case '+':if(feof(fp)) return p;
	       else if((c=fgetc(fp))=='=')
		   {      
			   q.b[++i]=c;
			   break;
		   }
	       else {fseek(fp,-1,1);break;}
  case '-':if(feof(fp)) return p;
	       else if((c=fgetc(fp))=='=')
		   {      
			   q.b[++i]=c;
			   break;
		   }
	       else {fseek(fp,-1,1);break;}
  case '*':if(feof(fp)) return p;
	       else if((c=fgetc(fp))=='=')
		   {      
			   q.b[++i]=c;
			   break;
		   }
		   else if(c=='/')
		   {      
			   q.b[++i]=c;
			   break;
		   }
	       else {fseek(fp,-1,1);break;}
  case '!':if(feof(fp)) return p;
	       else if((c=fgetc(fp))=='=')
		   {      
			   q.b[++i]=c;
			   break;
		   }
	       else {fseek(fp,-1,1);break;}
  case '|':if(feof(fp)) return p;
	       else if((c=fgetc(fp))=='|')
		   {      
			   q.b[++i]=c;
			   break;
		   }
	       else {fseek(fp,-1,1);break;}
  case '&':if(feof(fp)) return p;
	       else if((c=fgetc(fp))=='&')
		   {      
			   q.b[++i]=c;
			   break;
		   }
	       else {fseek(fp,-1,1);break;}
  case '%':if(feof(fp)) return p;
	       else if((c=fgetc(fp))=='d')
		   {      
			   q.b[++i]=c;
			   break;
		   }
	       if(c=='f')
		   {      
			   q.b[++i]=c;
			   break;
		   }
	       else {fseek(fp,-1,1);break;}
  case '<':if(feof(fp)) return p;
	       else if((c=fgetc(fp))=='=')
		   {      
			   q.b[++i]=c;
			   break;
		   }
	       if(c=='<')
		   {      
			   q.b[++i]=c;
			   break;
		   }
	       else {fseek(fp,-1,1);break;}
  case '>':if(feof(fp)) return p;
	       else if((c=fgetc(fp))=='=')
		   {      
			   q.b[++i]=c;
			   break;
		   }
	       if(c=='>')
		   {      
			   q.b[++i]=c;
			   break;
		   }	      
	       else {fseek(fp,-1,1);break;}
  case 'a': case 'b': case 'c': case 'd': case 'e': case 'f': case 'g': case 'h':
  case 'i': case 'j': case 'k': case 'l': case 'm': case 'n': case 'o': case 'p': 
  case 'q': case 'r': case 's': case 't': case 'u': case 'v': case 'w': case 'x':
  case 'y': case 'z': case 'A': case 'B': case 'C': case 'D': case 'E': case 'F':
  case 'G': case 'H': case 'I': case 'J': case 'K': case 'L': case 'M': case 'N': 
  case 'O': case 'P': case 'Q': case 'R': case 'S': case 'T': case 'U': case 'V': 
  case 'W': case 'X': case 'Y': case 'Z': case '_':
    while(!feof(fp))
	{
       c=fgetc(fp);
	   switch(c)
		{
		 case 'a': case 'b': case 'c': case 'd': case 'e': case 'f': case 'g': case 'h':
         case 'i': case 'j': case 'k': case 'l': case 'm': case 'n': case 'o': case 'p': 
         case 'q': case 'r': case 's': case 't': case 'u': case 'v': case 'w': case 'x':
         case 'y': case 'z': case 'A': case 'B': case 'C': case 'D': case 'E': case 'F':
         case 'G': case 'H': case 'I': case 'J': case 'K': case 'L': case 'M': case 'N': 
         case 'O': case 'P': case 'Q': case 'R': case 'S': case 'T': case 'U': case 'V': 
         case 'W': case 'X': case 'Y': case 'Z': case '_': case '0': case '1': case '2':
		 case '3': case '4': case '5': case '6': case '7': case '8': case '9': q.b[++i]=c;break;
		 default : fseek(fp,-1,1);fale=1;break;	 
		}
		if(fale==1) break;
	}
	if(feof(fp)) return p;
  case '0': case '1': case '2': case '3': case '4':
  case '5': case '6': case '7': case '8': case '9':
	 while(!feof(fp))
	 {
		  c=fgetc(fp);
		switch(c)
		{
			case '0': case '1': case '2': case '3': case '4': case '5': case '6':
            case '7': case '8': case '9': q.b[++i]=c;break;
			default : fseek(fp,-1,1);fale=1;break;
        }
		if(fale==1) break;
	  }
	 if(feof(fp)) return p;
   }
   q.b[i+1]='\0';
   return q;
 }
  else return p;

}
/***********************************************/
void creatHash()/*根表的初始化*/
{
	int i;
	for(i=0;i<SIZE;i++)
	{
		hash[i].ip=-1;
		hash[i].link=NULL;
	}
}
//****************************************************
int h(char *p)/*求hash函數的值&&&&&&&&&&&&&&&&&&&&*/
{
 int i;
 char a[1];
 for(i=0;i<MAX;i++)
	 if(strcmp(token[i],p)==0) {return i+1;break;}
 a[0]=*p;
 switch(a[0])
 {case 'a': case 'b': case 'c': case 'd':
  case 'e': case 'f': case 'g': case 'h':
  case 'i': case 'j': case 'k': case 'l':
  case 'm': case 'n': case 'o': case 'p':
  case 'q': case 'r': case 's': case 't':
  case 'u': case 'v': case 'w': case 'x':
  case 'y': case 'z': return a[0]-63;break;
  case 'A': case 'B': case 'C': case 'D':
  case 'E': case 'F': case 'G': case 'H':
  case 'I': case 'J': case 'K': case 'L':
  case 'M': case 'N': case 'O': case 'P':
  case 'Q': case 'R': case 'S': case 'T':
  case 'U': case 'V': case 'W': case 'X':
  case 'Y': case 'Z': return a[0]-5;break;
  case '_': return 86;break;
  case '+': if(*(p+1)=='+')return 87;
	      else if(*(p+1)=='=') return 88; 
	      else return 89; break;
  case '-': if(*(p+1)=='-')return 90;
          else if(*(p+1)=='=') return 91; 
	      else return 92; break;
  case '*': if(*(p+1)=='=') return 93;
	        else if(*(p+1)=='/')return 95;
	      else return 94; break;
  case '/':if(*(p+1)=='*')return 95;
			else   return 96;break;
  case '>':if(*(p+1)=='=') return 97;
           else if(*(p+1)=='>')return 98;
		   else return 99;break;
  case '<':if(*(p+1)=='=') return 100;
           else if(*(p+1)=='<')return 101;
		   else return 102;break;
  case '(':return 103;break; case ')':return 104;break; case ':':return 105;break;
  case '#':return 124;break; case '.':return 125;break; case '{':return 126;break;
  case '}':return 127;break; case '[':return 128;break; case ']':return 129;break;
  case '"':return 130;break; case '\'':return 131;break;case ';':return 132;break;
  case '!':if(*(p+1)=='=')return 106;
			else   return 107;break; 
  case '|':if(*(p+1)=='|')return 108;
			else   return 109;break; 
  case '&':if(*(p+1)=='&')return 110;
			else   return 110;break;
  case '%':if(*(p+1)=='d')return 111;
           else if(*(p+1)=='f')return 112;
			else   return 113;break;
  case '0':case '1':case '2':case '3':case '4':case '5':case '6':
  case '7':case '8':case '9':return a[0]+66;break;
  default : {printf("is not biao zi fu\n");return -1;}
 }
}




//*************************************************
int zhifutype(char *p)/*找字符串的類型*/
{
 int pi,i;
 char c;
 for(i=0;i<MAX;i++)
  if((strcmp(p,token[i]))==0)
  {pi=1; break;}
 if(i>=MAX)
 {
   c=*p;
   switch(c)
   {
    case '0':case '1':case '2':case '3':case '4':case '5':case '6':
    case '7':case '8':case '9':pi=3;break;
    case '+':case '>':case '<':case '=':case '#':case '(':
    case ')':case '{':case '}':case '[':case ']':
    case '%':case '&':case '|':case '?':case '!':pi=4;break;
    case '-':c=*(p+1);
	     if(c=='>')pi=5;
	     else pi=4; break;
    case '/':c=*(p+1);
	     if(c=='*')pi=5;
	     else pi=4; break;
    case '*':c=*(p+1);
	     if(c=='/')pi=5;
	     else pi=4; break;
    case ';':case '"':case ',':case ':':case '.':case '\'': pi=6;break;
    default : pi=2;
   }
 }
 return pi;
}
//*********************************************
int searchHash(char *p)/*hash表的查找*/
{
 int potion,xp;
 potion=h(p);
 printf("位置為:%d\n",potion);
 xp=zhifutype(p);
 if(hash[potion].link==NULL)
 {
     printf("hash表中沒有\n");
	 return -1;
 }
 else
 {
	 struct node *x;
	 x=hash[potion].link;
	 while(x->next!=NULL&&(strcmp(x->data,p)!=0))
		 x=x->next;
	 if(strcmp(x->data,p)==0)
	 {
		printf("hash表中有\n"); 
		return 0;
	 }
	 else
	 {
        printf("hash表中沒有\n");
	    return -1;
	 }
 }
}



//********************************************
void insertHash(char *p)/*hash表的創建及解決沖突*/
{
 int potion,xp;
 struct node *q;
 q=(struct node *)malloc(sizeof(struct node));
 strcpy(q->data,p);
 q->next=NULL;
 potion=h(p);
 xp=zhifutype(p);
 if(hash[potion].link==NULL)
 {
	 hash[potion].ip=xp;
     hash[potion].link=q;
	 printf("%s插入表中了\n",p);
 }
 else
 {
  struct node *x;  
   x=hash[potion].link;
  while(x->next!=NULL)x=x->next;
   x->next=q;
   printf("%s插入表中了\n",p);
 }
}
/************************************/
void display()
{
	int i;
    struct node *x;
	for(i=0;i<SIZE;i++)
	{
		x=hash[i].link;
		while(x!=NULL)
		{
			printf("(%d,%s)",hash[i].ip,x->data);
			x=x->next;
		}
	}
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲男同1069视频| 欧美色图片你懂的| 一区二区成人在线观看| 精品国产免费一区二区三区香蕉| 国产精品一品二品| 五月激情综合色| 亚洲美女在线国产| 久久精品一区八戒影视| 欧美成人vps| 欧美久久久久久久久中文字幕| 91久久一区二区| 久久精品久久久精品美女| 不卡视频在线看| 国产精品久久看| 国产a级毛片一区| 亚洲最大的成人av| 日韩一二三区视频| 欧美在线999| 一本一道综合狠狠老| 国产麻豆精品95视频| 激情欧美一区二区| 国产一区啦啦啦在线观看| 中文字幕一区二区三区色视频| 在线观看网站黄不卡| 奇米影视7777精品一区二区| 亚洲婷婷综合色高清在线| 国产午夜精品久久久久久免费视| 成人国产免费视频| 国产精品性做久久久久久| 国产在线精品免费av| 国产精品正在播放| 北条麻妃一区二区三区| 日韩高清欧美激情| 舔着乳尖日韩一区| 中文字幕一区二区三区蜜月| 国产精品女同一区二区三区| 国产精品色眯眯| 26uuu国产日韩综合| 久久蜜臀中文字幕| 欧美激情在线一区二区| 国产精品剧情在线亚洲| 国产精品国产a级| 久久综合一区二区| 欧美极品美女视频| 亚洲成a天堂v人片| 麻豆精品久久精品色综合| 国产精品夜夜嗨| 97久久超碰精品国产| 欧美在线观看视频在线| 欧美久久久久久久久久| 欧美理论在线播放| 蜜桃视频在线观看一区| 久久精品国内一区二区三区| 国产99久久久精品| 欧美视频在线观看一区二区| 久久这里只有精品视频网| 成人免费在线视频| 久久精品国产99国产精品| 国产宾馆实践打屁股91| 欧美中文一区二区三区| 国产传媒日韩欧美成人| 欧美性videosxxxxx| 精品剧情v国产在线观看在线| 国产精品美女一区二区| 日本va欧美va精品| 91久久精品一区二区三区| 精品久久久久久最新网址| 天天av天天翘天天综合网色鬼国产| 国产福利一区二区三区视频在线 | 亚洲综合一二区| 丰满亚洲少妇av| 精品国一区二区三区| 亚洲综合免费观看高清完整版在线| 国产激情视频一区二区在线观看| 9191久久久久久久久久久| 一区二区三区免费| 91在线精品一区二区| 国产亚洲精久久久久久| 日韩1区2区3区| 4438成人网| 国产精品麻豆网站| av电影天堂一区二区在线| 久久久电影一区二区三区| 国产一区二区精品久久91| 日韩一区二区三区视频在线观看 | 日本视频免费一区| 欧美高清hd18日本| 首页国产欧美久久| 欧美一区二区美女| 狠狠色综合播放一区二区| 精品国产成人系列| 精品一区二区三区蜜桃| 久久久久国产免费免费| 成人免费视频网站在线观看| 日韩一区中文字幕| 欧美日韩国产综合视频在线观看 | 精品av久久707| 国产a级毛片一区| 精品国产乱码久久久久久蜜臀| 国产一区在线观看麻豆| 中文字幕五月欧美| 色先锋资源久久综合| 一区二区三区不卡视频在线观看 | 精品国精品自拍自在线| 国产激情精品久久久第一区二区| 国产精品传媒入口麻豆| 欧美猛男超大videosgay| 青青青伊人色综合久久| 国产性色一区二区| 欧美美女喷水视频| 国产精品1024| 婷婷成人激情在线网| 国产丝袜欧美中文另类| 欧美日韩和欧美的一区二区| 成人深夜视频在线观看| 日韩二区三区四区| 一区二区免费在线| 国产精品久久影院| 日韩欧美一二三四区| av亚洲精华国产精华精| 国产河南妇女毛片精品久久久 | 夫妻av一区二区| 日韩成人午夜电影| 亚洲国产欧美在线| 久久久久久免费毛片精品| 日韩免费性生活视频播放| 欧美日韩国产影片| 日本韩国欧美国产| 91色九色蝌蚪| 成人免费视频app| 乱一区二区av| 免费在线看一区| 日韩高清不卡一区二区| 18欧美亚洲精品| 欧美精品一区二区三区蜜臀| 91麻豆精品国产| 色婷婷精品大视频在线蜜桃视频| 成人免费高清视频| 99久久伊人精品| 91在线观看免费视频| 色哟哟日韩精品| 一本久久综合亚洲鲁鲁五月天| 国产69精品久久777的优势| 国产99精品在线观看| 成人污污视频在线观看| 色综合久久99| 91精品国产综合久久久久久| 7777精品伊人久久久大香线蕉完整版 | 国产精品你懂的在线欣赏| 91免费版在线| 欧美亚洲丝袜传媒另类| 欧美日韩国产首页在线观看| 精品久久久久久久久久久久久久久 | 欧美日韩亚洲国产综合| 国产日产精品一区| 日本网站在线观看一区二区三区 | 99在线精品视频| 日韩精品在线看片z| 午夜成人免费视频| 色狠狠色噜噜噜综合网| 欧美极品少妇xxxxⅹ高跟鞋 | 91福利视频网站| 亚洲色图制服诱惑 | 不卡免费追剧大全电视剧网站| 91精品国产一区二区三区香蕉| 最新中文字幕一区二区三区| 国产伦精品一区二区三区视频青涩 | 国产最新精品免费| 精品久久久久久综合日本欧美| 亚洲国产一区二区视频| 欧美日韩专区在线| 亚洲一级电影视频| 欧美视频一区二区三区四区 | 欧美日韩国产影片| 婷婷中文字幕综合| 欧美一区二区三区四区高清 | 久久爱www久久做| xnxx国产精品| 国产69精品久久久久毛片| 久久亚洲一区二区三区四区| 国产一区二区三区在线看麻豆| 亚洲欧洲三级电影| 丁香五精品蜜臀久久久久99网站| 国产亚洲欧美日韩俺去了| 国产成人av一区二区三区在线 | 欧美日韩一区二区三区不卡 | 毛片av一区二区| 国产丝袜欧美中文另类| 色视频欧美一区二区三区| 日韩电影在线观看网站| 国产日韩欧美电影| 欧美系列亚洲系列| 国产乱码精品1区2区3区| 一区二区不卡在线视频 午夜欧美不卡在 | 国产成a人亚洲| 久久久久久夜精品精品免费| 91在线一区二区| 久久精品国产在热久久| 国产精品三级在线观看| 91国偷自产一区二区开放时间 |