80c51用计算器程序

//由于这原本是写给c51用的c程序,所以没有添加stdio等标准库
//并且考虑到51RAM有限,大部分变量用unsigned char以节省空间

include “operation.h”

char stack1[55], stack2[55];
int pt1=-1, pt2=-1;

void push(char ch, unsigned short i)
{
if(i==1)stack1[++pt1]=ch;
else if(i==2)stack2[++pt2]=ch;
}

char pop(unsigned short i)
{
if(i==1)return stack1[pt1–];
else return stack2[pt2–];
}

char top(unsigned short i)
{
if(i==1)return stack1[pt1];
else return stack2[pt2];
}

void RPExpression(char exp[])
{
unsigned char i;
unsigned char ch, temp;
push(‘@’,1);
for(i=0;exp[i]!=’\0’;i++)
{
ch=exp[i];
switch(ch)
{
case ‘(‘:
push(’ ‘,2);
push(ch,1);
break;
case ‘)’:
push(’ ‘,2);
while(top(1)!=’(‘)
{
temp=pop(1);
push(temp,2);
}
pop(1);//弹出’(’
break;
case ‘+’:
case ‘-‘:
push(’ ‘,2);
while(top(1)==’*’||top(1)==’/’||top(1)==’+’||top(1)==’-‘)
{
temp=pop(1);
push(temp,2);
}
push(ch,1);
break;
case ‘*’:
case ‘/’:
push(’ ‘,2);
while(top(1)==’*’||top(1)==’/’)
{
temp=pop(1);
push(temp,2);
}
push(ch,1);
break;
default:
push(ch,2);
break;
}
}
while(pt1>0)
{
temp=pop(1);
push(temp,2);
}
}

float getPRExpvalue()
{
float stack3[40];
int pt3=-1;

unsigned char i, j, dot=0, left, right, ch;
float fir, sec, num, fra;

//for(i=0;i<40;i++)stack3[i]=0;

for(i=0;stack2[i]!='\0';i++)
{
    ch=stack2[i];
    if(ch>='0'&&ch<='9')
    {
        left=i;
        right=80;
        fra=num=dot=0;
        for(j=i+1;;j++)
        {
            if(stack2[j]=='.'){dot=j; continue;}
            if(!(stack2[j]>='0'&&stack2[j]<='9')){right=j-1; i=j-1; break;}
        }
        if(right!=80)
        {
            if(dot==0)
            {
                for(j=left;j<=right;j++)num=num*10+(stack2[j]-'0')*1.0;
                fra=0;
            }
            else
            {
                for(j=left;j<dot;j++)num=num*10+(stack2[j]-'0')*1.0; for(j="right;j">dot;j--)fra=(fra+(stack2[j]-'0')*1.0)/10.0;
            }
            stack3[++pt3]=num+fra;
        }
    }
    else if(ch=='+'||ch=='-'||ch=='*'||ch=='/')
    {
        fir=stack3[pt3--];
        sec=stack3[pt3--];
        switch(ch)
        {
            case '+':
                num=sec+fir;
                break;
            case '-':
                num=sec-fir;
                break;
            case '*':
                num=sec*fir;
                break;
            case '/':
                num=sec/fir;
                break;
        }
        stack3[++pt3]=num;
    }
}
return stack3[pt3];

}

void initialStack()
{
unsigned char i;
for(i=0;i<55;i++)stack1[i]=stack2[i]=’\0’;
pt1=pt2=-1;
}

以下是头文件

ifndef __OPERATION_H

define __OPERATION_H

void initialStack();//初始化栈空间
void RPExpression(char exp[]);//转化为逆波兰表达式
float getPRExpvalue();//获取逆波兰表达式的值

endif

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
51计算器程序#include #include #define uchar unsigned char #define uint unsigned int sbit lcden=P3^4; sbit lcdrw=P3^6; sbit lcdrs=P3^5; uchar num,temp,jia=0,cheng=0,chu=0,jian=0,qing=0; uint key,key1,shu; uchar fuhao,flag1,flag=0; uchar table[]={ 0x3F,0x06,0x5B,0x4F,0x66,0x6D,0x7D,0x07,0x7F,0x6F,0x00,}; void delay(uint z) { uint x,y; for(x=z;x>0;x--) for(y=114;y>0;y--); } bit lcd_bz() { bit result; lcdrs = 0; lcdrw= 1; lcden = 1; _nop_(); _nop_(); _nop_(); _nop_(); result=(bit)(P0&0x80;); lcden=0; return result; } void write_com(uchar com) { while(lcd_bz()); lcdrs=0; lcden=0; lcdrw=0; P0=com; delay(5); lcden=1; delay(5); lcden=0; } void write_date(uchar date) { while(lcd_bz()); lcdrs=1; lcden=0; lcdrw=0; P0=date; delay(5); lcden=1; delay(5); lcden=0; } void lcd_init() { lcden=0; write_com(0x38); write_com(0x0c); write_com(0x06); write_com(0x01); } void keyscan() { P3=0xfe; temp=P3; temp=temp&0xf0; while(temp!=0xf0) { delay(5); temp=P3; temp=temp&0xf0; while(temp!=0xf0) { temp=P3; switch(temp) { case 0xee:key=1;num=0;break; case 0xde:key=2;num=0;break; case 0xbe:key=3;num=0;break; case 0x7e:num=1;break; //¼ÓºÅ } while(temp!=0xf0) { temp=P3; temp=temp&0xf0; } } } P3=0xfd; temp=P3; temp=temp&0xf0; while(temp!=0xf0) { delay(5); temp=P3; temp=temp&0xf0; while(temp!=0xf0) { temp=P3; switch(temp) { case 0xed:key=4;num=0;break; case 0xdd:key=5;num=0;break; case 0xbd:key=6;num=0;break; case 0x7d:num=2;break; //¼õºÅ } while( temp!=0xf0) { temp=P3; temp=temp&0xf0; } } } P3=0xfb; temp=P3; temp=temp&0xf0; while(temp!=0xf0) { delay(5); temp=P3; temp=temp&0xf0; while(temp!=0xf0) { temp=P3; switch(temp) { case 0xeb:key=7;num=0;break; case 0xdb:key=8;num=0;break; case 0xbb:key=9;num=0;break

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值