建议撤掉部分递归题解
查看原帖
建议撤掉部分递归题解
1436908
EternalRights楼主2024/12/10 12:29

大多数和递归相关的题解会出现运行错误的情况,包括排名第一的题解。或许是时过境迁导致的编译问题吧。不过题解思路是对的。 因而为了不误导后人建议撤掉递归代码,只需要保留思路即可。
代码部分可以参考我的:

#include <bits/stdc++.h>
 
using namespace std;
using i64 = long long;
using u64 = unsigned long long;
using u32 = unsigned;
using pii = pair<int,int>;

string work(string& s,int& start){
	string ans;
	for ( ; start < s.size(); ++start){
		if ( s[start] == '['){
			int num = 0;
			start++;
			while(isdigit(s[start])){
				num = num * 10 + (s[start++] - '0');
			}
			string ss = work(s,start);
			while(num--){
				ans += ss;
			}
		} else if ( s[start] == ']'){
			return ans;
		} else{
			ans += s[start];
		}
	}

	return ans;
}

int main(){
    cin.tie(nullptr);
	ios::sync_with_stdio(false);

	string str;
	cin >> str;
	int start = 0;
	cout << work(str,start) << endl;

	return 0;
}
2024/12/10 12:29
加载中...