#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万+
最新资源
- 基于珊格地图的人工势场法 动态路径规划 路径规划算法 地图好修改 自己研究编写的Matlab路径规划 可自行设置起始点,目标点,自由更地图 - 可以和A*和RRT
- 基于51单片机的无线通信智能定时插座 本系统采用STC89C52RC单片机为主控制器,由DS1302时钟芯片、SIM900A模块、DS18B20温度传感器、LCD1602液晶屏、ADE7755电能计量
- Matlab+yalmip+cplex安装 提供详细安装步骤,提供安装包和cplex破解版,可以远程,远程加20,包成功 不要相信一些没有技术的人说有版本限制,我这个没有限制,任何版本都可以用
- MATLAB代码:基于多时间尺度滚动优化的多能源微网双层调度模型 关键词:多能源微网 多时间尺度 滚动优化 微网双层模型 调度 仿真平台:MATLAB 优势:代码注释详实,适合参考学习,非网上烂大街
- 无刷直流电机bldc(BLDC)无位置或者有位置传感器sim
- 电动汽车充电负荷预测,出行链,OD矩阵,蒙特卡洛模拟
- Linux命令大全,Linux命令大全
- 差分升级 增量升级 单片机 STM32 IAP升级OTA升级,物联网车联网可用 单片机-STM32可用的打补丁还原算法源码 如图所示174k的bin文件生成的差分文件只有33字节,非常适合物联网,车
- MATLAB代码:基于二阶锥优化电气综合能源系统优化调度研究 关键词:电气综合能源 优化调度 二阶锥优化 参考文档:《考虑气电联合需求响应的气电综合能源配网系统协调优化运行》参考部分配电网设备模型,非
- 利用GitHub进行数据存储和共享
- MATLAB代码:基于主从博弈的电热综合能源系统动态定价与能量管理 关键词:主从博弈 热电联产 动态定价 能量 参考文档:店主自编文档,完全复现 仿真平台:MATLAB +cplex 优势:代码
- MATLAB代码:基于局部优化的大规模电动汽车随机充放电策略优化 关键词:电动汽车充放电优化 电动汽车 局部优化 充放电策略 参考文档:Optimal Scheduling for Chargi
- 图书管理系统,基于python+flask+mysql的前后端开发的图书管理系统 包运行,附源码
- KtAdmin-ChatGPT-chatgpt
- C++ 源代码 : 基于OpenGL和TensorRT实现的PC端实时人脸美颜系统 运行于Win10 64位系统,用CUDA和TensorRT实现人脸位置检测和106关键点检测,用OpenGL和GLS
- 如何使用GitHub进行代码版本控制
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈