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

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

?? hangkongdingpiao.c

?? 數據結構課程設計用C實現的航空訂票系統
?? C
?? 第 1 頁 / 共 3 頁
字號:
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<time.h>
#define MAX 13
#define OK 1
#define TRUE 1
#define FALSE 0
#define ERROR 0
#define OVERFLOW -2
#define OPSETSIZE 7
#define STACK_INIF_SIZE 50
#define STACKINCREMENT 10
#define PR printf
int number[2][4];     
typedef int status;
typedef struct airline{
	char line_num[8];//航班號
	char plane_num[8];//飛機號
	char end_place[20];//目的地
	int total;//座位總數
	int left;//剩余座位
	struct airline *next;//下一個結點
}airline;

typedef struct customer{
	char name[9];//顧客名
	char line_num[8];//航班號
	int seat_num;//座位號
	struct customer *next;//下一個結點
}customer;

airline *init_airline(){//初始化鏈表
	airline *l;
	l=(airline*)malloc(sizeof(airline));
	if(l==NULL){
		exit(0);
		}
	l->next=NULL;
	return l;
}

customer * init_customer(){//初始化鏈表
	customer *l;
	l=(customer*)malloc(sizeof(customer));
	if(l==NULL){
		exit(0);
		}
	l->next=NULL;
	return l;
}

status insert_airline(airline **p,char *line_num,char *plane_num,char *end_place,int total,int left){//airline鏈表插入操作
	airline *q;
	q=(airline*)malloc(sizeof(airline));
	/*{
		PR("內存分配失敗\n");
		return OVERFLOW;
	}*/
	strcpy(q->line_num , line_num);
	strcpy(q->plane_num , plane_num);
	strcpy(q->end_place , end_place);
	q->total  =total;
	q->left =left;
	q->next=NULL;
	(*p)->next=q;
	(*p)=(*p)->next;
 //   PR("insert %d	,%dis succssed!\n",e,bl);
	return OK;
	}

status insert_customer(customer **p,char *name,char *line_num,int seat){//customer鏈表插入操作
	customer *q;
	q=(customer*)malloc(sizeof(customer));
/*	{
		PR("內存分配失敗\n");
		return OVERFLOW;
	}*/
	strcpy(q->name , name);
	strcpy(q->line_num , line_num);
	q->seat_num =seat;
	q->next=NULL;
	(*p)->next=q;
	(*p)=(*p)->next;
 //   PR("insert %d	,%dis succssed!\n",e,bl);
	return OK;
	}

airline *modefy_airline(airline *l,char *line_num)//修改airline鏈表中的數據
{
	airline *p;
	p=l->next ;
	for(;p!=NULL;p=p->next )
	{
		if(strcmp(line_num,p->line_num )==0)
		{
			p->left ++;
	//		PR("modefy %s\n",p->line_num );
			return l;
		}
	}
	PR("沒有這個航班,無法完成修改任務!\n");
	return 0;
}

status delete_airline(airline *h,char *line_num)//刪除航班
{
	airline *p,*pr;
	pr=h;
	p=pr->next ;
	while(p!=NULL)
	{
		if(strcmp(line_num,p->line_num )==0)
		{
			pr->next =p->next ;
			PR("刪除  %s  航班\n",p->line_num  );
			return OK;
		}
		pr=pr->next ;
		p=pr->next ;
	}
	PR("無此航班,無法刪除!\n");
	return ERROR;
}

status delete_customer(customer *h,char *line_num)//刪除顧客
{
	customer *p,*pr;
	pr=h;
	p=pr->next ;
	while(p!=NULL)
	{
		if(strcmp(line_num,p->line_num )==0)
		{
			pr->next =p->next ;
		}
		pr=pr->next ;
		p=pr->next ;
	}
//	PR("無此航班,無法刪除!\n");
	return OK;
}

status delete_cus(customer *h,airline *l,char *name)//顧客退票
{	
	customer *p,*pr;
	char line_num[8];
//	qr=h;
	pr=h;
	p=pr->next ;
//	PR("開始刪除\n");
	while(p!=NULL)
	{
		if(strcmp(name,p->name )==0)
		{
			strcpy(line_num,p->line_num );
			l=modefy_airline(l,line_num);
			pr->next =p->next ;
			PR("顧客 %s 退票成功!\n",p->name );
			return OK;
		}
		pr=pr->next ;
		p=pr->next ;
	}
	PR("無此顧客,無法退票!\n");
	return ERROR;
}

status save_airline(airline *l)//保存airline.dat
{
	FILE *fp_airline;
	char ch='#';
	airline *p=l->next ;
	char filename[]="c:\\airline.dat";
	if((fp_airline=fopen(filename,"wb"))==NULL)
	{
		printf("can not open file to write:%s\n",filename);
		return ERROR;
	}
	for(;p!=NULL;p=p->next )
	{
	//	printf("%s,%s,%s,%d,%d\n",p->line_num ,p->plane_num ,p->end_place ,p->total ,p->left );
		fprintf(fp_airline,"%s,%s,%s,%d,%d%c\n",p->line_num ,p->plane_num ,p->end_place ,p->total ,p->left ,ch);
	}	
	fclose(fp_airline);
	return OK;
}

status save_customer(customer *l)//保存顧客信息 customer.dat
{
	FILE *fp_customer;
	char ch='#';
	customer *p=l->next ;
	char filename[]="c:\\customer.dat";
	if((fp_customer=fopen(filename,"wb"))==NULL)
	{
		printf("can not open file to write:%s\n",filename);
		return ERROR;
	}
	for(;p!=NULL;p=p->next )
	{
	//	PR("%s,%s,%d\n",p->name ,p->line_num ,p->seat_num );
		fprintf(fp_customer,"%s,%s,%d%c",p->name ,p->line_num ,p->seat_num ,ch);
	}	
	fclose(fp_customer);
	return OK;
}	

int changStrInt(char *ch)//把字符串轉化為整型
{
	int a=1,b=0,c=0,i;
	for (i=strlen(ch)-1;i>=0;i--)
	{
		if (ch[i]<58&&ch[i]>47)
		{
			b=a*(ch[i]-48);
			a=a*10;
			c=c+b;

		}
		else 
		{
			PR("%c 不合法,無法將此字符串轉化為整形!\n",ch[i]);
			return 0;
		}
//	printf("the c is %d\n",c);
	}
	return c;
}

status creat_airline(airline **l)//創建airline單鏈表
{
	airline *p=*l;
	int i=0;
	char *line_num[3]={"bjgy01","bjsh02","shgz03"};
	char *plane_num[3]={"plane1","plane2","plane3"};
	char *end_place[3]={"貴陽","上海","廣州"};
	int total[3]={100,100,100};
	int left[3]={51,50,78};
	for (i=0;i<3;i++){
		insert_airline(&p,line_num[i],plane_num[i],end_place[i],total[i],left[i]);
	}
	return OK;
}

status creat_customer(customer **l)////創建customer單鏈表
{
	customer *p=*l;
	int i=0;
	char *name[3]={"李勇","張潔","劉勝"};
	char *line_num[3]={"bjgy01","bjsh02","shgz03"};
	int seat_num[3]={1,5,10};
	for (i=0;i<3;i++){
		insert_customer(&p,name[i],line_num[i],seat_num[i]);
	}
	return OK;
}

status increase_air(airline *l,char *line_num,char *plane_num,char *end_place,int total)//增加航線
{
	airline *p=l->next ;
	for(;p->next !=NULL;p=p->next){}
	insert_airline(&p,line_num,plane_num,end_place,total,total);
	PR("增加航班 %s 成功!\n",line_num);
	return OK;
}

status book(airline *l,char *line_num,customer *c,char *name)//訂票
{
	airline *p=l;	
	customer *q=c->next ;
	p=l->next ;
	for(;q->next !=NULL;q=q->next){}		
//	PR("%s\n",q->name );
	for(;p!=NULL;p=p->next )
	{
		if(strcmp(line_num,p->line_num )==0)
		{
			if(p->left >0)
			{
				PR("恭喜您!訂票成功!\n");
				PR("你的座位號是:  %d\n",(p->total -p->left +1));
				insert_customer(&q,name,line_num,p->total -p->left +1);
				p->left --;
				return OK;
			}
			else PR("對不起,座位已滿!\n");
			return 0;
		}
	}
	PR("對不起,沒有這個航班號!\n");
	return ERROR;
}

status print_airline(airline *l)//打印航線信息
{
	airline *p=l->next ;
	for(;p!=NULL;p=p->next )
	{
		PR("%8s%8s%8s%9d%9d\n",p->line_num ,p->plane_num ,p->end_place ,p->total ,p->left );
	}
	return OK;
}

status print_customer(customer *l)//打印顧客信息
{
	customer *p=l->next ;
	for(;p!=NULL;p=p->next )
	{
		PR("%10s      %10s       %d\n",p->name ,p->line_num ,p->seat_num );
	}
	return OK;
}

enum
{
	eNumber = 0,	//操作數
	eOperator = 1	//算子
};

int oper[7]={43,45,42,47,40,41,35};

typedef struct sqlist{
	int bol;//bol is 0 when num_ch is a number;bol is 1 when the num_ch is a oprater
	int num_ch;
	struct sqlist *next;
	}sqlist;

typedef struct sqstack{
	int *base;
	int *top;
	int stacksize;
	}sqstack;

unsigned char Prior[7][7] = {     // 表3.1  算符間的優先關系
  	  '>','>','<','<','<','>','>',
	  '>','>','<','<','<','>','>',
	  '>','>','>','>','<','>','>',
	  '>','>','>','>','<','>','>',	
	  '<','<','<','<','<','=',' ',
	  '>','>','>','>',' ','>','>',
	  '<','<','<','<','<',' ','='
};

char OPSET[OPSETSIZE]={'+' , '-' , '*' , '/' ,'(' , ')' , '#'};

status init_sq(sqlist *l){//初始化鏈表
	l=(sqlist*)malloc(sizeof(sqlist));
	if(l==NULL){
		exit(OVERFLOW);
		}
	l->next=NULL;
	return OK;
	}

status insert_sq(sqlist **p,int e,int bl){//鏈表插入操作
	sqlist *q;
	q=(sqlist*)malloc(sizeof(sqlist));
	q->num_ch=e;
	q->bol=bl;
	q->next=NULL;
	(*p)->next=q;
	(*p)=(*p)->next;
 //   printf("insert %d	,%dis succssed!\n",e,bl);
	return OK;
	}

int check(sqlist l)//保證輸入的數字是給出的四個數字
{
	int right=1,find=0,i;
	sqlist *q=&l;
	q=q->next ;
	for (;q->next!=NULL;q=q->next){
		if(q->bol==1){
			if(q->num_ch <=39||q->num_ch>57||q->num_ch==44||q->num_ch==46){
				right=0;
				printf("%c不是有效的運算符!\n");
			}
		}
		else {
			find=0;
			for(i=0;i<4;i++){
				if(number[1][i]==0&&number[0][i]==q->num_ch ){
					number[1][i]=1;
					find=1;
					break;
				}
			}
			if(find==0){				
				printf("%d 不在給出的四個數字中!\n",q->num_ch );
				right=0;
			}
		}
	}//end for
//	printf("the right is %d\n",right);
/*	for (i=0;i<4;i++){
		printf("number[1][%d]=%d\n",i,number[1][i]);
	}*/
	for (i=0;i<4;i++){
		if(number[1][i]==0){
			printf("%d沒有用上!\n",number[0][i]);
			right=0;
		}
	}
	return right;
	
}

int chang(char *s,sqlist *l){//將用戶的輸入轉化為單鏈表
	int t=0;
	unsigned int i=0;
   	 int bl,ch;
	int a1,a2,a;
	sqlist *p=l;
	for (;i<strlen(s);i++){
		if(s[i]>47&&s[i]<58&&t==0){
			a1=(int)s[i]-48;
			t++;
			}
		else if(s[i]>47&&s[i]<58&&t==1){
			a2=(int)s[i]-48;
			a=a1*10+a2;
			t++;
            }
		else if(s[i]<48&&s[i]>39&&s[i]!=44&&s[i]!=46){
			if(t==1){
                        bl=0;
						insert_sq(&p,a1,bl);
		                t=0;
				}
			else if(t==2){
				bl=0;
				insert_sq(&p,a,bl);
                t=0;
				}
			bl=1;
			ch=(int)s[i];
			insert_sq(&p,ch,bl);
            t=0;
			}
		else {
			printf("%c不是有效的運算符!\n",s[i]);
		}
		}   //end for
	i=strlen(s)-1;
	if(s[i]>47&&s[i]<58){
		if(s[i-1]>47&&s[i-1]<58){
		           bl=0;
			   insert_sq(&p,a,bl);
			   }
		else {
			bl=0;
			insert_sq(&p,a1,bl);
			}
		}
	bl=1;
	a=35;
	insert_sq(&p,a,bl);
//    printf("chang is OK\n");
	return (check(*l));
	}

/*status print_sq(sqlist *l)
{
	sqlist *p=l;
	if(l){
		for (p=p->next ;p!=NULL;p=p->next){

				printf("%d,%d\n",p->num_ch,p->bol );

				//printf("OK!");
				}
		}
	else printf("空!");
	return OK;
}*/

int Operate(int a,int theta, int b) {//計算
//	printf("a=%d,theta=%c,b=%d\n",a,theta,b);
   switch(theta) {

      case 43: return a+b;
      case 45: return a-b;
      case 42: return a*b;
      case 47:
		  {
			  if(b==0){
			//	printf("除數不能為0!\n");
				return -2000;
			//	exit(ERROR);
				}
			  if (a%b==0){
			  return a/b;
			  }
			  else {
			  //printf("不能為小數\n");
				return -100;
			 // exit(0);
			  }
		  }
      default : return 0;
   } 

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美美女黄视频| 国产精品女同互慰在线看| 91精品国产色综合久久| 久久精品日韩一区二区三区| 亚洲欧美偷拍三级| 国产一区中文字幕| 欧美日韩免费电影| 亚洲日本va午夜在线影院| 久久精工是国产品牌吗| 91成人免费在线视频| 国产日韩欧美一区二区三区乱码| 日日夜夜一区二区| 91黄色激情网站| 中文字幕一区免费在线观看| 国产在线观看免费一区| 欧美精品亚洲二区| 午夜精品123| 欧美日韩精品一区二区在线播放| 国产精品福利一区| 成人一区二区三区| 久久久天堂av| 国产精品夜夜嗨| 久久久久国产精品麻豆ai换脸 | 欧美极品xxx| 美国一区二区三区在线播放| 欧美精品少妇一区二区三区| 亚洲午夜av在线| 在线视频一区二区三| 亚洲精品中文在线| 91日韩在线专区| 亚洲色图.com| 色悠悠亚洲一区二区| 亚洲欧美综合另类在线卡通| 99久久婷婷国产综合精品| 国产免费久久精品| 成人黄色av电影| 综合久久久久久久| 色综合久久综合网欧美综合网| 亚洲视频综合在线| 色婷婷精品久久二区二区蜜臀av | 国产精品你懂的| 成人视屏免费看| 自拍偷拍国产精品| 91亚洲精品乱码久久久久久蜜桃 | 欧美婷婷六月丁香综合色| 亚洲精品videosex极品| 欧美综合欧美视频| 天天射综合影视| 精品国产免费人成电影在线观看四季| 久久99精品国产麻豆婷婷| 久久久精品tv| 在线这里只有精品| 无码av免费一区二区三区试看 | 综合自拍亚洲综合图不卡区| 一本在线高清不卡dvd| 亚洲一区自拍偷拍| 欧美xxxx老人做受| 成人av网址在线观看| 亚洲午夜羞羞片| 日韩欧美视频一区| 成人福利在线看| 性做久久久久久久免费看| 日韩精品一区二区三区三区免费| 国产九九视频一区二区三区| 亚洲免费在线视频一区 二区| 制服视频三区第一页精品| 国产精品12区| 亚洲va在线va天堂| 国产日韩欧美精品一区| 欧美吻胸吃奶大尺度电影| 国产精品一区在线观看你懂的| 亚洲男人的天堂在线观看| 日韩欧美国产小视频| 91在线porny国产在线看| 琪琪久久久久日韩精品| 中文字幕佐山爱一区二区免费| 欧美一级免费大片| 97se狠狠狠综合亚洲狠狠| 日韩国产一二三区| 亚洲精品国产品国语在线app| 26uuu欧美| 欧美福利电影网| 91麻豆精品视频| 国产一区二区三区四区五区美女| 亚洲3atv精品一区二区三区| 中文字幕第一区第二区| 欧美一区二区三区不卡| 欧美性xxxxxx少妇| yourporn久久国产精品| 久久草av在线| 日本午夜一区二区| 一区二区三区在线影院| 国产精品视频一区二区三区不卡| 欧美卡1卡2卡| 在线观看亚洲a| 不卡的av在线播放| 国产精品99久久久久| 秋霞国产午夜精品免费视频| 亚洲成a人在线观看| 亚洲欧洲三级电影| 国产欧美日韩另类一区| 精品久久久久久久久久久院品网| 欧美剧情电影在线观看完整版免费励志电影| 国产91在线观看丝袜| 国产在线不卡一区| 激情文学综合插| av在线这里只有精品| 国产乱子轮精品视频| 久久国产精品72免费观看| 青青草伊人久久| 日韩高清一级片| 亚洲国产精品久久久久秋霞影院| 亚洲视频中文字幕| 亚洲视频网在线直播| 亚洲视频资源在线| 亚洲免费观看高清完整版在线 | 7777精品伊人久久久大香线蕉的 | 日韩vs国产vs欧美| 青青草97国产精品免费观看 | 亚洲精品ww久久久久久p站| 亚洲色图20p| 亚洲综合在线免费观看| 亚洲综合成人在线| 亚洲国产精品一区二区尤物区| 亚洲国产精品欧美一二99| 亚洲午夜av在线| 日韩不卡免费视频| 国模无码大尺度一区二区三区| 激情综合五月婷婷| 国产成人av一区二区| 99久久国产免费看| 欧美性猛片xxxx免费看久爱| 欧美精品乱码久久久久久按摩 | 综合分类小说区另类春色亚洲小说欧美| 国产精品私人影院| 亚洲欧美日韩国产成人精品影院 | 欧美日韩黄色一区二区| 欧美久久一区二区| 久久久综合激的五月天| 国产精品不卡在线观看| 亚洲精品日日夜夜| 日本一区中文字幕| 国产精品系列在线观看| 色综合久久中文综合久久牛| 欧美精品1区2区| 久久久99精品免费观看| 一区二区三区四区av| 美美哒免费高清在线观看视频一区二区 | 美女一区二区视频| 国产69精品久久777的优势| 在线视频一区二区三| 日韩一区二区电影网| 国产精品久久久久久久久免费樱桃 | 欧美在线视频日韩| 精品国产乱子伦一区| 亚洲欧美激情插| 九色综合狠狠综合久久| 91天堂素人约啪| 日韩欧美一区中文| 亚洲精品免费在线播放| 美国毛片一区二区| 色天天综合久久久久综合片| 精品国产乱码久久久久久闺蜜 | 中日韩av电影| 日韩中文字幕区一区有砖一区| 国产成人在线观看免费网站| 欧美高清www午色夜在线视频| 国产精品每日更新| 蜜桃久久久久久| 91色九色蝌蚪| 国产无遮挡一区二区三区毛片日本| 亚洲精品中文在线影院| 国产成人丝袜美腿| 777亚洲妇女| 亚洲精品福利视频网站| 国产传媒一区在线| 日韩一级完整毛片| 亚洲电影中文字幕在线观看| 成人网在线播放| 亚洲精品一线二线三线| 五月天网站亚洲| 在线观看av一区| 国产精品二三区| 国产精品亚洲午夜一区二区三区| 制服丝袜av成人在线看| 亚洲国产三级在线| 色94色欧美sute亚洲线路一久| 亚洲国产精品二十页| 国产一区二区三区久久久| 日韩免费看的电影| 日韩福利电影在线观看| 欧美在线你懂的| 亚洲精品乱码久久久久久久久 | 亚洲精品五月天| 一本色道a无线码一区v| 国产精品久久久久天堂| 国产成人免费xxxxxxxx| 国产亚洲一区字幕| 国产成人免费av在线| 国产亚洲综合性久久久影院|