【问题标题】:How to remove + from std::string如何从 std::string 中删除 +
【发布时间】:2021-04-02 17:58:43
【问题描述】:

我想创建一个比数字和小表达式更高级的计算器程序。我需要完成的首要任务之一是检查输入的表达式是否有效,在此我想确保括号有效。我从控制台得到一个 std::string 并且我想将表达式简化为以下内容:(, ), [, ], {, }。

bool in (char elem, std::vector<char> V) {
    for (char c : V) {
        if (c == elem) {
            return true;
        }
    }
    return false;
}

void valid_parentheses(std::string s) {
    // first remove the spaces
    s.erase(std::remove_if(s.begin(), s.end(), isspace), s.end());
    std::vector<char> valid = { '(', '[', '{', ')', ']', '}' };

    for (long unsigned int c = 0; c < s.size(); c++) {
        if (!in(s[c], valid) {
            s.erase(s.begin() + c);
        }
    }
    std::cout << "New string: " << s << std::endl;
}

如果我用输入调用它: ( ( 1 + 5 ) * [ 3 + 4 ] )

$ g++ main.cpp -o output && ./output
( ( 1 + 5 ) * [ 3 + 4 ] )

我得到了输出

New string: ((+)[+])

这大多是成功的,但我不知道为什么 + 符号仍然存在。

我知道还有许多其他方法可以完成此操作,例如,如果我看到所需的字符之一来获取括号、大括号等,则附加到另一个字符串,但我仍然很好奇为什么 + 符号仍然存在。

【问题讨论】:

  • in的定义是什么?请发minimal reproducible example
  • 问题不是真正的 + 是吗?任何 3+ 符号组合不会导致这种情况吗? IE。甚至是“123”。因为您没有调整删除符号时用于迭代的整数索引c
  • @PeterT,你是对的,但我不确定你调整整数索引是什么意思以及我应该将其调整为什么
  • 我真的认为事先验证括号没有什么意义:虽然它可以确保括号本身是平衡的,但它不会告诉你括号在完整表达式中是否处于合法位置。考虑表达式(1+)
  • @G.Sliepen,我试图采取一种简单的方法,分部分执行这些步骤,因此:检查括号是否有效,如果有效,请处理其他事情。

标签: c++ string char


【解决方案1】:

在您的循环中,当您到达要删除的字符时,您不会修改索引c。这意味着您跳过被擦除字符之后的每个字符。一个简单的解决方法是在擦除时减少 c

if (!in(s[c], valid) {
    s.erase(s.begin() + c);
    c--; // here  
}

当然,您应该只使用一种算法,就像您删除空格一样:

s.erase(std::remove_if(s.begin(), s.end(), [&](auto c){
    return !in(c, valid);
}), s.end());

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2014-01-25
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2019-12-27
    • 1970-01-01
    相关资源
    最近更新 更多