广告
返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >C语言实现数学表达式运算
  • 685
分享到

C语言实现数学表达式运算

2024-04-02 19:04:59 685人浏览 独家记忆
摘要

本文实例为大家分享了C语言实现数学表达式运算的具体代码,供大家参考,具体内容如下 1、开发思路: (假设有表达式 2 * 3 * ( 1 + 2) ) 数字要一个一个取出放在内存中,

本文实例为大家分享了C语言实现数学表达式运算的具体代码,供大家参考,具体内容如下

1、开发思路: (假设有表达式 2 * 3 * ( 1 + 2) )

数字要一个一个取出放在内存中,根据相邻前后2个计算符号,判断是否要取出数字进行计算,2个数字的计算值重新放在内存中且顺序放置。考虑使用栈这种数据结构去保存数字和符号,用2个栈,1个栈保存数字,一个栈保存运算符号。

2、因要使用栈这种数据结构,本代码使用纯C语言开发,故先编写栈的代码,参考:
c语言实现通用数据结构(三):通用椎栈

3、重要处理逻辑

(1)如何判断前后2个运算符的优先级关系

(2)如何字符转换为数字

因键盘输入的内容为字符类型,需要判断输入的字符类型且进行必要转换
ASCII码表,表头依次为:二进制 十进制 十六进制 字符

(3)如何判断表达式处理完毕

默认先预置一个符号#,输入内容2 * 3 * ( 1 + 2)# ,当符号栈内为#,且当前处理的字符为#。则表达式处理完毕。

4、代码实现


#define _CRT_SECURE_NO_DEPRECATE

#define _CRT_SECURE_CPP_OVERLOAD_STANDARD_NAMES 1

#include <stdlib.h>
#include <stdio.h>
#include "myStack.h"

// 判断是否操作符
int ifOp(char c) {
    switch (c) {
    case '+':
        return 1;
    case '-':
        return 1;
    case '*':
        return 1;
    case '/':
        return 1;
    case '(':
        return 1;
    case ')':
        return 1;
    case '#':
        return 1;
    default:
        break;
    }
    return 0;
}

int findOffset(char * str,char c,int len) {
    for (int i = 0; i < len;i++) {
        if (str[i] == c) {
            return i;
        }
    }
    return -1;
}

//判断任意相继出现的2个运算符的优先级
char yxji(char op1,char op2) {
    char ops[] = "+-*/()#";
    char oplist[7][7] = { 
        ">><<<>>",
        ">><<<>>",
        ">>>><>>",
        ">>>><>>" ,
        "<<<<<=&",
        ">>>>&>>",
        "<<<<<&="};
    int len = sizeof(ops) / sizeof(char);
    return oplist[findOffset(ops,op1, len)][findOffset(ops, op2, len)];
}

//基础运算 a-第1个数  b-第2个数
void baseOp(char op,int a,int b,int * value) {
    printf("baseOp %d %c %d",a,op,b);
    //int value = 0;
    //int* p = &value;
    switch (op) {
    case '+':
        *value = a + b;
        break;
    case '-':
        *value = a-b;
        break;
    case '*':
        *value = a*b;
        break;
    case '/':
        *value = a/b;
        break;
    default:
        printf("运算符不合法");
        exit(1);
    }
}

//转换字符为数字
void transValue(char  c,int * v) {
    if (c > 47 && c < 58) {
        *v =  (c - 48);
    }
}

void printstack(MyStack * stack1,MyStack * stack2) {
    int len1 = myListGetSize(stack1);
    int len2 = myListGetSize(stack2);
    printf("stack1值:");
    for (int i = 0; i < len1;i++) {
        char* m = (char*)myListGetDataAt(stack1,i );
        printf("%c ", *m);
    }
    printf("\nstack2值:");
    for (int i = 0; i < len2; i++) {
        int* m = (int*)myListGetDataAt(stack2, i);
        printf("%d(%p) ", *m,m);
    }
    printf("\n");
}

// 计算,该方法只能对数字 0-9 运算(可掌握栈、指针的使用)
// 2*3*(1+2)#
void calculate(char bds[]) {
    int i = 0;
    char flag = '#';
    MyStack* stack1 = createMyStack();//stack1中放运算符
    myStackPush(stack1, &flag);
    MyStack* stack2 = createMyStack();//stack2中放数字
    //char c = bds[i]; // 等价于*(bds+i) 
    while (bds[i] != '#' || *(char*)myStackGetTop(stack1)!='#') {
        printstack(stack1,stack2);
        if (!ifOp(bds[i])) {
             
            int* vu = (int*)malloc(sizeof(int));
            transValue(bds[i], vu);
            printf("is number:%d\n", *vu);//打印出数字
            myStackPush(stack2, vu);
            i++;
        }
        else {
            printf("is fuhao:%c\n", bds[i]);
            char * op1 = (char*)myStackGetTop(stack1);
            printf("top1 op:%c\n",*op1);
            if (*op1 == '#') {
                myStackPush(stack1, &bds[i]);
                i++;
                continue;
            }
            char res = yxji(*op1, bds[i]);
            printf("yxji:%c\n",res);
            switch (res) {
                case '>':{
                    char* curop = (char*)myStackPop(stack1);//取出当前运算符
                    printf("top2 op:%c\n", *op1);
                    int* b = (int*)myStackPop(stack2);//第2个运算数
                    int* a = (int*)myStackPop(stack2);//第1个运算数
                    
                    int* value = (int*)malloc(sizeof(int));
                    baseOp(*curop, *a, *b, value);
                    printf("=%d\n", *value);
                    myStackPush(stack2, value);
                    break;
                }
                case '<':
                    myStackPush(stack1, &bds[i]);
                    i++;
                    break;
                case '=': {
                    printf("()==");
                    myStackPop(stack1);//取出右括号 (
                    i++;
                    break;
                }
                default:
                    printf("表达式错误!");
                    exit(1);
            }
        }
    }
    int * valueRes = (int*)myStackPop(stack2);
    printf("计算结果值为:%d\n",*valueRes);

    freeMyList(stack1);
    freeMyList(stack2);
}

int main() {
    printf("输入表达式:\n");
    char bds[50];
    scanf("%s",bds);// 数组变量名,传入的相当于是数组第一个元素的地址。方法形参是个指针变量,指针变量才能存放地址
    calculate(bds);
    return 0;
}

5、代码开发过程总结 (踩坑填坑真实记录)

将符号转为数字并把数字放入栈中,若写为如下形式不行
int vv = 0;
transValue('1‘, &vv);
myStackPush(stack2, vv);

因为临时变量地址始终不变,第2个值赋值后,等于是把已放入栈内的第一个值修改了(程序中通过打印出指针变量值,即变量的地址,发现地址确实没变)
应该用如下方式:

int* vv= (int*)malloc(sizeof(int));
transValue('1‘, vv);
myStackPush(stack2, vv);

掌握指针用法很重要!此处记录如下:

6. 代码测试结果(开发环境:visual studio 2019)

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程网。

--结束END--

本文标题: C语言实现数学表达式运算

本文链接: https://www.lsjlt.com/news/158513.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • C语言实现数学表达式运算
    本文实例为大家分享了C语言实现数学表达式运算的具体代码,供大家参考,具体内容如下 1、开发思路: (假设有表达式 2 * 3 * ( 1 + 2) ) 数字要一个一个取出放在内存中,...
    99+
    2022-11-12
  • C语言如何实现数学表达式运算
    C语言如何实现数学表达式运算,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。大家分享了C语言实现数学表达式运算的具体代码,具体内容如下开发思路: (假设有表达式 2 * 3 ...
    99+
    2023-06-21
  • C语言运算符与表达式
    目录表达式函 数 概 述赋值运算符与赋值表达式变量赋初值自动类型转换强制类型转换算数运算符与表达式算术运算符算术表达式优先级与结合性自增自减运算符关系运算符与表达式优先级与结合性逻辑...
    99+
    2022-11-13
  • C语言运算符与表达式实例分析
    本篇内容主要讲解“C语言运算符与表达式实例分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C语言运算符与表达式实例分析”吧!表达式函 数 概 述表达式是C语言的主体。在C语言中,表达式由操作符...
    99+
    2023-07-02
  • c语言逻辑表达式的运算规则是什么
    C语言逻辑表达式的运算规则如下:1. 逻辑与(&&):如果两个操作数都为真(非零),则结果为真;否则为假(0)。2. 逻辑或(||)...
    99+
    2023-08-16
    c语言
  • 关于c语言逗号表达式的运算规则知识点
    逗号表达式是一个有多个子表达式组成的表达式,每个子表达式用逗号分隔。逗号表达式的运算规则如下:1. 逗号表达式从左到右依次计算每个子...
    99+
    2023-08-15
    C语言
  • C语言数学公式来实现土味表白
    目录前言:一、首先简介一下所需要用到的知识点以及各个知识点的用法二、最后我们来上程序总结前言:        在学习了一些编程基础以后,尤其学习了scanf函数以后,我觉得scanf...
    99+
    2022-11-12
  • 如何使用C语言数学公式来实现表白
    这篇文章主要介绍如何使用C语言数学公式来实现表白,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!一、首先简介一下所需要用到的知识点以及各个知识点的用法(1)输出函数:printf();(printf()是C语言标准库函...
    99+
    2023-06-22
  • C语言简明讲解三目运算符和逗号表达式的使用
    目录一、三目运算符二、逗号表达式三、小结一、三目运算符 三目运算符( a b : c)可以作为逻辑运算的载体 规则:当 a 的值为真时,返回 b 的值;否则返回 c 的值 下面看一...
    99+
    2022-11-13
  • 汇编语言怎么实现简单数学运算
    这篇文章主要介绍“汇编语言怎么实现简单数学运算”,在日常操作中,相信很多人在汇编语言怎么实现简单数学运算问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”汇编语言怎么实现简单数学运算”的疑惑有所帮助!接下来,请跟...
    99+
    2023-06-21
  • C语言如何实现平方运算
    小编给大家分享一下C语言如何实现平方运算,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!平方运算a = pow...
    99+
    2022-10-19
  • c语言移位运算的实现方式有哪些
    C语言中移位运算有两种方式:左移和右移。1. 左移运算:用">"表示,将一个数的各二进位全部右移若干位,低位丢弃,高位补0或补1,取...
    99+
    2023-09-14
    c语言
  • C语言运用回调函数实现计算器
    本文实例为大家分享了C语言运用回调函数实现计算器的具体代码,供大家参考,具体内容如下 回调函数概念: 回调函数是一个通过函数指针调用的函数,也就是将函数的地址作为参数传递给另一个函数...
    99+
    2022-11-12
  • c语言重载运算符怎么实现
    C语言不支持重载运算符,只能通过函数来实现类似的功能。例如,可以通过定义一个函数来代替重载的加法运算符: #include ty...
    99+
    2023-10-25
    c语言
  • C#判断语句的表达式树实现
    C# 提供了以下类型的判断语句: 语句描述if一个 if 语句 由一个布尔表达式后跟一个或多个语句组成。if...else一个 if 语句 后...
    99+
    2022-11-12
  • 学习Go语言文档中的regexp.MatchString函数实现正则表达式匹配
    学习Go语言文档中的regexp.MatchString函数实现正则表达式匹配简介正则表达式是一种强大的工具,用来匹配和操作字符串。在Go语言中,我们可以使用内置的regexp包来处理正则表达式。其中的MatchString函数可以用来判断...
    99+
    2023-11-03
    文档 关键词:Go语言 regexpMatchString
  • 学习Go语言文档中的regexp.MustCompile函数实现正则表达式匹配
    学习Go语言文档中的regexp.MustCompile函数实现正则表达式匹配正则表达式(Regular Expression)是一种用于匹配、搜索、替换字符串的强大工具。在Go语言中,使用regexp包提供了对正则表达式的支持。其中的Mu...
    99+
    2023-11-03
    正则表达式 匹配 关键词:Go语言
  • C语言实现矩阵运算案例详解
    C语言实现矩阵运算 给定一个n×n的方阵,本题要求计算该矩阵除副对角线、最后一列和最后一行以外的所有元素之和。副对角线为从矩阵的右上角至左下角的连线。 输入格式: 输入第一行给出正整...
    99+
    2022-11-12
  • C语言实现BMP图像闭运算处理
    闭运算可以把比结构元素小的特定图像细节出去,同时保证不产生全局的几何失真。填充比结构元素小的缺口或孔,搭接短的间断而起到连接作用。 运算:也就是先膨胀后腐蚀。 #include ...
    99+
    2022-11-12
  • C语言实现BMP图像开运算处理
    开运算可以把比结构元素小的特定图像细节出去,同时保证不产生全局的几何失真。滤掉比结构元素小的突刺,切断细长搭接而起到分离作用。 运算:用B开启A就是选出了A中某些与B相匹配的点,这些...
    99+
    2022-11-12
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作