四则运算/华为机试(C/C++)

2024-03-28 05:32
文章标签 c++ 华为 四则运算 机试

本文主要是介绍四则运算/华为机试(C/C++),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目描述

请实现如下接口

    /* 功能:四则运算

     * 输入:strExpression:字符串格式的算术表达式,如: "3+2*{1+2*[-4/(8-6)+7]}"

         * 返回:算术表达式的计算结果

     */

    public static int calculate(String strExpression)

    {

        /* 请实现*/

        return 0;

    } 

约束:

  1. pucExpression字符串中的有效字符包括[‘0’-‘9’],‘+’,‘-’, ‘*’,‘/’ ,‘(’, ‘)’,‘[’, ‘]’,‘{’ ,‘}’。

  2. pucExpression算术表达式的有效性由调用者保证; 

输入描述:

输入一个算术表达式

输出描述:

得到计算结果

示例1

输入

3+2*{1+2*[-4/(8-6)+7]}

输出

25

代码:借用

#include<iostream>
#include<string>
#include<vector>
#include<stack>
using namespace std;
int main() 
{string s;while (cin >> s) {stack<char> opera;vector<int> numcnt;string s1;//后缀表达式//中缀表达式转后缀表达式for (int i = 0; i<s.size(); i++) {if (s[i] >= '0'&&s[i] <= '9') {int tmp = 0;while (s[i] >= '0'&&s[i] <= '9') {tmp++;s1 += s[i];i++;}i--;numcnt.push_back(tmp);}else if (s[i] == '-' || s[i] == '+') {if (s[i] == '-' && (s[i - 1] == '(' || s[i - 1] == '[' || s[i - 1] == '{'))s1 += '0';while (!opera.empty() && (opera.top() == '*' || opera.top() == '/' || opera.top() == '+' || opera.top() == '-')) {s1 += opera.top();opera.pop();}opera.push(s[i]);}else if (s[i] == '*' || s[i] == '/') {while (!opera.empty() && (opera.top() == '*' || opera.top() == '/')) {s1 += opera.top();opera.pop();}opera.push(s[i]);}else if (s[i] == '(' || s[i] == '[' || s[i] == '{')opera.push(s[i]);else if (s[i] == ')') {while (opera.top() != '(') {s1 += opera.top();opera.pop();}opera.pop();}else if (s[i] == ']') {while (opera.top() != '[') {s1 += opera.top();opera.pop();}opera.pop();}else if (s[i] == '}') {while (opera.top() != '{') {s1 += opera.top();opera.pop();}opera.pop();}elsecout << "Invalid input!" << endl;}while (!opera.empty()) {s1 += opera.top();opera.pop();}//计算后缀表达式的值stack<int> nums;int ind = 0;for (int i = 0; i<s1.size(); i++) {if (s1[i] >= '0'&&s1[i] <= '9') {int total = 0;while (numcnt[ind]--)total = 10 * total + (s1[i++] - '0');i--;nums.push(total);ind++;}else {int tmp1 = nums.top();nums.pop();int tmp2 = nums.top();nums.pop();if (s1[i] == '+')nums.push(tmp2 + tmp1);else if (s1[i] == '-')nums.push(tmp2 - tmp1);else if (s1[i] == '*')nums.push(tmp2*tmp1);elsenums.push(tmp2 / tmp1);}}cout << nums.top() << endl;}
}

 

这篇关于四则运算/华为机试(C/C++)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/854586

相关文章

Java调用C++动态库超详细步骤讲解(附源码)

《Java调用C++动态库超详细步骤讲解(附源码)》C语言因其高效和接近硬件的特性,时常会被用在性能要求较高或者需要直接操作硬件的场合,:本文主要介绍Java调用C++动态库的相关资料,文中通过代... 目录一、直接调用C++库第一步:动态库生成(vs2017+qt5.12.10)第二步:Java调用C++

C/C++错误信息处理的常见方法及函数

《C/C++错误信息处理的常见方法及函数》C/C++是两种广泛使用的编程语言,特别是在系统编程、嵌入式开发以及高性能计算领域,:本文主要介绍C/C++错误信息处理的常见方法及函数,文中通过代码介绍... 目录前言1. errno 和 perror()示例:2. strerror()示例:3. perror(

C++变换迭代器使用方法小结

《C++变换迭代器使用方法小结》本文主要介绍了C++变换迭代器使用方法小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录1、源码2、代码解析代码解析:transform_iterator1. transform_iterat

详解C++中类的大小决定因数

《详解C++中类的大小决定因数》类的大小受多个因素影响,主要包括成员变量、对齐方式、继承关系、虚函数表等,下面就来介绍一下,具有一定的参考价值,感兴趣的可以了解一下... 目录1. 非静态数据成员示例:2. 数据对齐(Padding)示例:3. 虚函数(vtable 指针)示例:4. 继承普通继承虚继承5.

C++中std::distance使用方法示例

《C++中std::distance使用方法示例》std::distance是C++标准库中的一个函数,用于计算两个迭代器之间的距离,本文主要介绍了C++中std::distance使用方法示例,具... 目录语法使用方式解释示例输出:其他说明:总结std::distance&n编程bsp;是 C++ 标准

C++ 中的 if-constexpr语法和作用

《C++中的if-constexpr语法和作用》if-constexpr语法是C++17引入的新语法特性,也被称为常量if表达式或静态if(staticif),:本文主要介绍C++中的if-c... 目录1 if-constexpr 语法1.1 基本语法1.2 扩展说明1.2.1 条件表达式1.2.2 fa

C++中::SHCreateDirectoryEx函数使用方法

《C++中::SHCreateDirectoryEx函数使用方法》::SHCreateDirectoryEx用于创建多级目录,类似于mkdir-p命令,本文主要介绍了C++中::SHCreateDir... 目录1. 函数原型与依赖项2. 基本使用示例示例 1:创建单层目录示例 2:创建多级目录3. 关键注

C++从序列容器中删除元素的四种方法

《C++从序列容器中删除元素的四种方法》删除元素的方法在序列容器和关联容器之间是非常不同的,在序列容器中,vector和string是最常用的,但这里也会介绍deque和list以供全面了解,尽管在一... 目录一、简介二、移除给定位置的元素三、移除与某个值相等的元素3.1、序列容器vector、deque

C++常见容器获取头元素的方法大全

《C++常见容器获取头元素的方法大全》在C++编程中,容器是存储和管理数据集合的重要工具,不同的容器提供了不同的接口来访问和操作其中的元素,获取容器的头元素(即第一个元素)是常见的操作之一,本文将详细... 目录一、std::vector二、std::list三、std::deque四、std::forwa

C++字符串提取和分割的多种方法

《C++字符串提取和分割的多种方法》在C++编程中,字符串处理是一个常见的任务,尤其是在需要从字符串中提取特定数据时,本文将详细探讨如何使用C++标准库中的工具来提取和分割字符串,并分析不同方法的适用... 目录1. 字符串提取的基本方法1.1 使用 std::istringstream 和 >> 操作符示