1

我在匹配包含“|”的字符串时遇到了很大的困难 (ascii 124) C++ 中的字符。在下面的代码方法中,每次运行它总是匹配最后一个 if 语句:

if (strComp == "D|A" || "D|M" || "A|D" || "M|D") {c = "010101";}

我试过逃避'|' 带有'\|'的符号 这没有用。令人惊讶的是,我在四处搜索时发现关于这个问题的信息很少。我忽略的代码是否还有其他问题?这是一个正常的ASCII字符,我的一部分认为这应该更容易......

string Code::comp(string strComp) {
string a = "0";
string c = "000000";

if (strComp.find('M') != -1) { a = "1"; }

if (strComp == "0") {c = "101010";}
if (strComp == "1") {c = "111111";}
if (strComp == "-1") {c = "111010";}
if (strComp == "D") {c = "001100";}
if (strComp == "A" || "M") {c = "110000";}
if (strComp == "!D") {c = "001101";}
if (strComp == "!A" || "!M") {c = "110001";}
if (strComp == "-D") {c = "001111";}
if (strComp == "-A" || "-M") {c = "110011";}
if (strComp == "D+1" || "1+D") {c = "011111";}
if (strComp == "A+1" || "M+1" || "1+A" || "1+M") {c = "110111";}
if (strComp == "D-1") {c = "001110";}
if (strComp == "A-1" || "M-1") {c = "110010";}
if (strComp == "D+A" || "D+M" || "A+D" || "M+D") {c = "000010";}
if (strComp == "D-A" || "D-M") {c = "010011";}
if (strComp == "A-D" || "M-D") {c = "000111";}
if (strComp == "D&A" || "D&M" || "A&D" || "M&D") {c = "000000";}
if (strComp == "D|A" || "D|M" || "A|D" || "M|D") {c = "010101";} // This matches every time

return a+c;
}

非常感谢您的帮助!贾斯汀

4

1 回答 1

7

代替

strComp == "D|A" || "D|M" 

你需要:

strComp == "D|A" || strComp == "D|M"

因为表达式strComp == "D|A"在运算符之前被评估,||所以你得到false || "D|M"或者true || "D|M"不是你想要的。

于 2012-05-20T16:11:42.047 回答