C语言 | Leetcode C语言题解之第227题基本计算题II

题目:

题解:

cpp 复制代码
int calculate(char* s) {
    int n = strlen(s);
    int stk[n], top = 0;
    char preSign = '+';
    int num = 0;
    for (int i = 0; i < n; ++i) {
        if (isdigit(s[i])) {
            num = num * 10 + (int)(s[i] - '0');
        }
        if (!isdigit(s[i]) && s[i] != ' ' || i == n - 1) {
            switch (preSign) {
                case '+':
                    stk[top++] = num;
                    break;
                case '-':
                    stk[top++] = -num;
                    break;
                case '*':
                    stk[top - 1] *= num;
                    break;
                default:
                    stk[top - 1] /= num;
            }
            preSign = s[i];
            num = 0;
        }
    }
    int ret = 0;
    for (int i = 0; i < top; i++) {
        ret += stk[i];
    }
    return ret;
}
相关推荐
和风化雨8 分钟前
排序算法--希尔排序
c语言·数据结构·c++·算法·排序算法
sjsjs1134 分钟前
【数据结构-Trie树】力扣677. 键值映射
数据结构·算法·leetcode
XY_墨莲伊9 小时前
【算法设计与分析】实验5:贪心算法—装载及背包问题
c语言·数据结构·c++·算法·贪心算法·排序算法
Happy_Traveller10 小时前
三角形的最大周长(976)
数据结构·算法·leetcode
咒法师无翅鱼10 小时前
【leetcode详解】T598 区间加法
算法·leetcode·职场和发展
涛ing11 小时前
【5. C++ 变量作用域及其深入探讨】
java·linux·c语言·开发语言·c++·ubuntu·vim
SY师弟12 小时前
蓝桥杯单片机第七届省赛
c语言·c++·单片机·嵌入式硬件·职场和发展·蓝桥杯
kcwqxx12 小时前
day37|完全背包基础+leetcode 518.零钱兑换II ,377.组合总和II
c++·算法·leetcode·动态规划
轩情吖12 小时前
二叉树-堆(补充)
c语言·数据结构·c++·后端·二叉树··排序
sjsjs1114 小时前
【数据结构-字典树】力扣14. 最长公共前缀
数据结构·leetcode