被强迫发的一帖(猿辅导第一题)

#include <iostream>
#include <vector>
#include <queue>
#include <string>
using namespace std;
class Solution{
public:
 vector<string> rev(vector<string> str){
 vector<string> res;
 for(int i = 0; i < str.size(); i++){
 res.push_back(helper(str[i]));
 }
 return res;
 }
 string helper(string s){
 if(s.size() == 0) return "";
 int i = 0;
 string res = "";
 while(i < s.size() && s[i] != '('){
 if(s[i] >= 'A' && s[i] <= 'Z'){
 res += s[i];
 i++;
 continue;
 }
 int num = s[i] - '0';
 i++;
 while(s[i] >= '0' && s[i] <= '9'){
 num = num * 10 + (s[i] - '0');
 i++;
 }
 string temp(num - 1, res[res.size() - 1]);
 res += temp;
 }
 if(i == s.size()) return res;
 int end = s.find_last_of(')');
 string res1 = helper(s.substr(i + 1,end - i - 1));
 i = end + 1;
 int num = 0;
 while(s[i] >= '0' && s[i] <= '9'){
 num = num * 10 + (s[i] - '0');
 i++;
 }
 for(int j = 0; j < num; j++){
 res += res1;
 }
 string res2 = helper(s.substr(i,s.size() - i));
 res += res2;
 return res;
 }
};
int main()
{
 int n;
 cin >> n;
 if(n <= 0) return 0;
 vector<string> str;
 string temp;
 for(int i = 0; i < n; i++){
 cin >> temp;
 str.push_back(temp);
 }
 Solution *s = new Solution();
 vector<string> res = s->rev(str);
 for(int i = 0; i < res.size(); i++){
 cout << res[i] << endl;
 }
 return 0;
}

#猿辅导##笔试题目#
全部评论
tql,一看就是大神,膜拜大神
点赞 回复 分享
发布于 2019-08-03 21:16

相关推荐

黑皮白袜臭脚体育生:简历统一按使用了什么技术实现了什么功能解决了什么问题或提升了什么性能指标来写会更好
点赞 评论 收藏
分享
评论
点赞
12
分享

创作者周榜

更多
牛客网
牛客企业服务