通过递归删除 C++ 中的给定子字符串来检查字符串是否可以变空
假设我们有两个字符串,str1和str2。str2是str1的子串,我们可以从str1中删除str2。字符串str2有可能在str1中出现多次。我们的目标是找出如果我们多次从str1中删除str2,则str1是否变为空字符串。如果可能,我们返回1,否则返回0。
所以,如果输入像str1="CCCPPPPPPP",str2="CPP";那么输出将为真。
示例(C++)
让我们看看以下实现以获得更好的理解-
#includeusing namespace std; bool solve(string str1, string str2) { while (str1.size() > 0) { int index = str1.find(str2); if (index == -1) break; str1.erase(index, str2.size()); } return (str1.size() == 0); } int main() { string str1 = "CCCPPPPPP", str2 = "CPP"; cout< 输入
"CCCPPPPPP", "CPP"输出结果1
热门推荐
10 宝宝生日祝福语大全简短
11 聚餐会祝福语简短
12 股市祝福语简短10字
13 许嵩生日祝福语简短
14 38节贺卡简短祝福语
15 生日牌祝福语英语简短
16 父亲祝福语大全简短语
17 英语简短祝福语给学生
18 初八祝福语简短语