#include <stdio.h>
#include <malloc.h>
#include <stdlib.h>
#include <string.h>
#include <conio.h>
/*字符操作函数*/
#include <ctype.h>
#define BUFFSIZE 32
#define COL 128
#define ROW 64
/* 【自学去】网站收集 http://www.zixue7.com */
/*定义栈1*/
typedef struct node
{
int data;
struct node *next;
}STACK1;
/*定义栈2*/
typedef struct node2
{
char data;
struct node2 *next;
}STACK2;
/*下面定义两个栈基本操作*/
/*入栈函数*/
STACK1 *PushStack(STACK1 *top,int x)
{
STACK1 *p;
p=(STACK1 *)malloc(sizeof(STACK1));
if(p==NULL)
{
printf("ERROR\n!");
exit(0);
}
p->data=x;
p->next=top;
top=p;
return top;
}
/*出栈函数*/
STACK1 *PopStack(STACK1 *top)
{
STACK1 *q;
q=top;
top=top->next;
free(q);
return top;
}
/*读栈顶元素*/
int GetTop(STACK1 *top)
{
if(top==NULL)
{
printf("Stack is null\n");
return 0;
}
/*返回栈顶元素*/
return top->data;
}
/*取栈顶元素,并删除栈顶元素*/
STACK1 *GetDelTop(STACK1 *top,int *x)
{
*x=GetTop(top);
top=PopStack(top);
return top;
}
int EmptyStack(STACK1 *top) /*判栈是否为空*/
{
if(top==NULL)
return 1;
return 0;
}
/*入栈函数*/
STACK2 *PushStack2(STACK2 *top,char x)
{
STACK2 *p;
p=(STACK2 *)malloc(sizeof(STACK2));
if(p==NULL)
{
printf("error\n!");
exit(0);
}
p->data=x;
p->next=top;
top=p;
return top;
}
STACK2 *PopStack2(STACK2 *top) /*出栈*/
{
STACK2 *q;
q=top;
top=top->next;
free(q);
return top;
}
/*读栈顶元素*/
char GetTop2(STACK2 *top)
{
if(top==NULL)
{
printf("Stack is null\n");
return 0;
}
return top->data;
}
/*取栈顶元素,并删除栈顶元素*/
STACK2 *GetDelTop2(STACK2 *top,char *x)
{
*x=GetTop2(top);
top=PopStack2(top);
return top;
}
/*判栈是否为空*/
int EmptyStack2(STACK2 *top)
{
if(top==NULL)
return 1;
else
return 0;
}
/*随机发牌函数*/
void GenCard()
{
int num,i;
randomize();
for(i=0;i<4;i++)
{
num=random(13); /*大小随机数*/
printf("%d ",num);
}
}
/*中缀字符串e转后缀字符串a函数*/
void ExpressTransform(char *expMiddle,char *expBack)
{
STACK2 *top=NULL; /* 定义栈顶指针*/
int i=0,j=0;
char ch;
while(expMiddle[i]!='\0')
{
/*判断字符是数字*/
if(isdigit(expMiddle[i]))
{
do{
expBack[j]=expMiddle[i];
i++;j++;
}while(expMiddle[i]!='.');
expBack[j]='.';
j++;
}
/*处理“(”*/
if(expMiddle[i]=='(')
top=PushStack2(top,expMiddle[i]);
/*处理“)”*/
if(expMiddle[i]==')')
{
top=GetDelTop2(top,&ch);
while(ch!='(')
{
expBack[j]=ch;
j++;
top=GetDelTop2(top,&ch);
}
}
/*处理加或减号*/
if(expMiddle[i]=='+'||expMiddle[i]=='-')
{
if(!EmptyStack2(top))
{
ch=GetTop2(top);
while(ch!='(')
{
expBack[j]=ch;
j++;
top=PopStack2(top);
if(EmptyStack2(top))
break;
else
ch=GetTop2(top);
}
}
top=PushStack2(top,expMiddle[i]);
}
/*处理乘或除号*/
if(expMiddle[i]=='*'||expMiddle[i]=='/')
{
if(!EmptyStack2(top))
{
ch=GetTop2(top);
while(ch=='*'||ch=='/')
{
expBack[j]=ch;
j++;
top=PopStack2(top);
if(EmptyStack2(top))
break;
else
ch=GetTop2(top);
}
}
top=PushStack2(top,expMiddle[i]);
}
i++;
}
while(!EmptyStack2(top))
top=GetDelTop2(top,&expBack[j++]);
expBack[j]='\0';
}
/*后缀表达式求值函数*/
int ExpressComputer(char *s)
{
STACK1 *top=NULL;
int i,k,num1,num2,result;
i=0;
while(s[i]!='\0') /*当字符串没有结束时作以下处理*/
{
if(isdigit(s[i])) /*判字符是否为数字*/
{
k=0; /*k初值为0*/
do{
k=10*k+s[i]-'0'; /*将字符连接为十进制数字*/
i++; /*i加1*/
}while(s[i]!='.'); /*当字符不为‘.’时重复循环*/
top=PushStack(top,k); /*将生成的数字压入堆栈*/
}
if(s[i]=='+') /*如果为'+'号*/
{
top=GetDelTop(top,&num2); /*将栈顶元素取出存入num2中*/
top=GetDelTop(top,&num1); /*将栈顶元素取出存入num1中*/
result=num2+num1; /*将num1和num2相加存入result中*/
top=PushStack(top,result); /*将result压入堆栈*/
}
if(s[i]=='-') /*如果为'-'号*/
{
top=GetDelTop(top,&num2); /*将栈顶元素取出存入num2中*/
top=GetDelTop(top,&num1); /*将栈顶元素取出存入num1中*/
result=num1-num2; /*将num1减去num2结果存入result中*/
top=PushStack(top,result); /*将result压入堆栈*/
}
if(s[i]=='*') /*如果为'*'号*/
{
top=GetDelTop(top,&num2); /*将栈顶元素取出存入num2中*/
top=GetDelTop(top,&num1); /*将栈顶元素取出存入num1中*/
result=num1*num2; /*将num1与num2相乘结果存入result中*/
top=PushStack(top,result); /*将result压入堆栈*/
}
if(s[i]=='/') /*如果为'/'号*/
{
top=GetDelTop(top,&num2); /*将栈顶元素取出存入num2中*/
top=GetDelTop(top,&num1); /*将栈顶元素取出存入num1中*/
result=num1/num2; /*将num1除num2结果存入result中*/
top=PushStack(top,result); /*将result压入堆栈*/
}
i++; /*i加1*/
}
top=GetDelTop(top,&result); /*最后栈顶元素的值为计算的结果*/
return result; /*返回结果*/
}
/*检查输入的表达式是否正确*/
int CheckExpression(char *e)
{
char ch;
int i=0;
while(e[i]!='\0')
{
if(isdigit(e[i]))
{
if(isdigit(e[i+1]))
{
i++;
continue;
}
if(e[i+1]!='.')
{
printf("\n The wrong express format!!\n");
return 0;
}
i++;
}
i++;
}
return 1;
}
/*主函数*/
int main()
{
char expMiddle[BUFFSIZE],expBack[BUFFSIZE],ch;
int i,result;
clrscr();
/*提示输入字符串格式*/
printf("*******************************************\n");
printf("| Welcome to play our game : 24 points! |\n");
printf("| The input format as follows: |\n");
printf("| 10.*(4.-3.) |\n");
printf("*******************************************\n");
while(1)
{
printf("\n The four digits are: ");
GenCard();
printf("\n");
do{
printf(" Please input the express:\n");
/*输入字符串压回车键*/
scanf("%s%c",expMiddle,&ch);
/*检查输入的表达式是否正确*/
}while(!CheckExpression(expMiddle));
printf("%s\n",expMiddle);
/*调用ExpressTransform函数将中缀表达式expMiddle转换为后缀表达式expBack*/
ExpressTransform(expMiddle,expBack);
/*计算后缀表达式的值*/
result=ExpressComputer(expBack);
printf("The value of %s is:%d.\n",expMiddle,result);
if(result==24)
printf("You are r
CrMylive.
- 粉丝: 1w+
- 资源: 4万+
最新资源
- 基于PyCharm和百度AI的智能停车场车牌识别计费系统说明
- 使用 Python 绘制简单而美观的 ASCII 圣诞树示例
- 全国各城市-农村-乡村户数(1999-2020年).xlsx
- 辅助Resx语言资源文件翻译程序
- Python实现AI智能联系人管理系统的操作指南
- 路径规划算法仿真 A星算法 传统A*(Astar)算法+改进后的A*算法 Matlab代码 可以固定栅格地图与起点终点 可以进行定量比较 改进: ①提升搜索效率(引入权重系数) ②冗余拐角优化(可显
- 基于 PyQt 的日志分析工具
- 机械设计电子烟自动装配组装机含工程图sw14可编辑非常好的设计图纸100%好用.zip
- 机械设计电子烟产品自动组装机sw16可编辑非常好的设计图纸100%好用.zip
- 使用 Python 和 Pygame 创建动态3D圣诞树效果
- 消费者行为数据集,消费者购买影响因素数据,营销行为预测数据集(该生成的数据集模拟了500名用户的营销互动数据)
- adf4150芯片加载程序
- 51商城程序使用手册:涵盖前后台功能详解与操作指南
- LSTM长短期记忆神经网络多输入多输出预测(Matlab) 所有程序经过验证,保证有效运行 1.data为数据集,10个输入特征,3个输出变量 2.MainLSTMNM.m为主程序文件 3.命
- 鸿蒙开发用户首选项demo
- 机械设计端面缺陷检测设备CCD检测机sw17可编辑非常好的设计图纸100%好用.zip
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈