标题:求一个用C语言开发一个多功能简易计算器,基本信息包括:四则运算、常见单位 ...
只看楼主
爱编程爱生活
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2020-7-7
结帖率:100%
已结贴  问题点数:20 回复次数:1 
求一个用C语言开发一个多功能简易计算器,基本信息包括:四则运算、常见单位转换。使之能提供以下两大部分功能
c语言开发一个多功能简易计算器,基本信息包括:四则运算、常见单位转换。使之能提供以下两大部分功能
搜索更多相关主题的帖子: 单位 四则运算 信息 开发 转换 
2020-07-07 15:40
纯蓝之刃
Rank: 12Rank: 12Rank: 12
等 级:贵宾
威 望:76
帖 子:554
专家分:3690
注 册:2019-7-29
得分:20 
给你一个四则运算的
程序代码:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

#define DATA                0
#define PARENTHESIS_LEFT    1
#define ADD_SUB                2
#define MUL_DIV                3
#define PARENTHESIS_RIGHT    4
#define MAX_LEN        256

union Value
{
    double value_f;
    char value_c;
};

struct SIGN
{
    union Value value;
    unsigned int flag;    //0.数据。1.2.3.符号
};

int main()
{
    double value[20];
    char buf[MAX_LEN],buf_temp[20];
    int i=0,mm=0,count=0,sign_len=-1,lose_len=0;;
    struct SIGN m_sign[20],m_infix[50],m_posfix[50];
    printf("请输入表达式,以#结束:");
    if(fgets(buf,MAX_LEN,stdin)!=NULL)
    {
        while(i<MAX_LEN&&buf[i]!='#')
        {
            while((buf[i]>='0'&&buf[i]<='9')||buf[i]=='.')    //读取数据
            {
                buf_temp[mm++]=buf[i];
                if(mm>=10)
                {
                    printf("出错!\n");
                    return -1;
                }
                i++;
            }
            if(mm>0)                                        //数据入栈
            {
                buf_temp[mm]='\0';
                m_infix[count].flag=DATA;
                m_infix[count].value.value_f=atof(buf_temp);
                count++;
                mm=0;
                continue;
            }

            switch(buf[i])
            {
            case '+':
                m_infix[count].flag=ADD_SUB;
                m_infix[count].value.value_c='+';
                count++;
                    break;
            case '-':
                m_infix[count].flag=ADD_SUB;
                m_infix[count].value.value_c='-';
                count++;
                break;
            case '*':
                m_infix[count].flag=MUL_DIV;
                m_infix[count].value.value_c='*';
                count++;
                break;
            case '/':
                m_infix[count].flag=MUL_DIV;
                m_infix[count].value.value_c='/';
                count++;
                break;
            case '(':
                m_infix[count].flag=PARENTHESIS_LEFT;
                m_infix[count].value.value_c='(';
                count++;
                break;
            case ')':
                m_infix[count].flag=PARENTHESIS_RIGHT;
                m_infix[count].value.value_c=')';
                count++;
                break;
            default:break;
            }
            i++;
        }

        mm=0;
        for(i=0;i<count;i++)
        {
            if(m_infix[i].flag==DATA)
            {
                m_posfix[mm].flag=m_infix[i].flag;
                m_posfix[mm].value.value_f=m_infix[i].value.value_f;
                mm++;
            }
            else
            {
                if(sign_len<0||m_infix[i].flag==PARENTHESIS_LEFT)
                {
                    lose_len++;
                    sign_len++;
                    m_sign[sign_len].flag=m_infix[i].flag;
                    m_sign[sign_len].value.value_c=m_infix[i].value.value_c;
                }
                else if(m_infix[i].flag==PARENTHESIS_RIGHT)
                {
                    lose_len++;
                    while(m_sign[sign_len].flag != PARENTHESIS_LEFT)
                    {
                        m_posfix[mm].flag=m_sign[sign_len].flag;
                        m_posfix[mm].value.value_c=m_sign[sign_len].value.value_c;
                        sign_len--;
                        mm++;
                        if(sign_len<0)
                        {
                            printf("出错!\n");
                            break;
                        }
                    }
                    sign_len--;
                }
                else if(m_infix[i].flag<m_sign[sign_len].flag)
                {
                    while(m_infix[i].flag<=m_sign[sign_len].flag&&m_sign[sign_len].flag!=PARENTHESIS_LEFT)
                    {
                        m_posfix[mm].flag=m_sign[sign_len].flag;
                        m_posfix[mm].value.value_c=m_sign[sign_len].value.value_c;
                        sign_len--;
                        mm++;
                        if(sign_len<0)
                            break;
                    }
                    sign_len++;
                    m_sign[sign_len].flag=m_infix[i].flag;
                    m_sign[sign_len].value.value_c=m_infix[i].value.value_c;
                }
                else 
                {
                    sign_len++;
                    m_sign[sign_len].flag=m_infix[i].flag;
                    m_sign[sign_len].value.value_c=m_infix[i].value.value_c;
                    printf("in2--%d,%d,%c\n",i,m_sign[sign_len].flag,m_sign[sign_len].value.value_c);
                }
            }
        }
        while(sign_len>=0)
        {
            m_posfix[mm].flag=m_sign[sign_len].flag;
            m_posfix[mm].value.value_c=m_sign[sign_len].value.value_c;
            sign_len--;
            mm++;
        }

        for(i=0;i<mm;i++)
        {
            if(m_posfix[i].flag==DATA)
                printf("%g,",m_posfix[i].value.value_f);
            else
                printf("%c,",m_posfix[i].value.value_c);
        }
        printf("\n");

        count=0;
        for(i=0;i<mm;i++)
        {
            if(m_posfix[i].flag==DATA)
                value[++count]=m_posfix[i].value.value_f;
            else
            {
                switch(m_posfix[i].value.value_c)
                {
                case '+':value[count-1]=value[count-1]+value[count];break;
                case '-':value[count-1]=value[count-1]-value[count];break;
                case '*':value[count-1]=value[count-1]*value[count];break;
                case '/':value[count-1]=value[count-1]/value[count];break;
                }
                count--;
            }
        }
        printf("result=%g\n",value[1]);
    }
    else
    {
        printf("输入的表达式有误,请重新输入!\n");
    }

    return 0;
}

一沙一世界,一花一天堂。无限掌中置,刹那成永恒。
2020-07-07 18:22



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-502428-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.228442 second(s), 7 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved