[leetcode]分治算法之Different Ways to Add Parenthese

╰+哭是因爲堅強的太久メ 2021-09-28 12:08 349阅读 0赞

分治算法之Different Ways to Add Parentheses

  • 分治的思考
  • 其他的学习
  • 题干
  • 答案

分治的思考

分治:把问题分为k份,然后再将这k份连起来。

方法:一般用递归来做。

注意:处理递归终止条件,即问题规模最小的情况

典型例题:归并排序、快速排序

其他的学习

string.substr(pos,len) 的用法

题干

leetcode入口

答案

很慢的一种答案,但是毕竟是自己想出来的。

先把数字和字符作为int从字符分离出来,存到一个vector<int>里面,注意运算符存的是位置

然后用递归对返回的vector<int>中的数字两两组合

  1. class Solution {
  2. public:
  3. vector<int> diffWaysToCompute(string input) {
  4. vector<int> res;
  5. vector<int> v; //存储字符和数字
  6. res.clear();
  7. v.clear();
  8. string a="";
  9. for(int i=0;i<input.size();i++){
  10. if(input[i]!='+' && input[i]!='-' && input[i]!='*'){
  11. a+=input[i];
  12. }
  13. else{
  14. v.push_back(stoi(a));
  15. a="";
  16. v.push_back(i); //把位置加进去
  17. }
  18. }
  19. v.push_back(stoi(a));
  20. if(v.size()==1) return v;
  21. for(int i=1;i<v.size();i=i+2){
  22. int index=v[i];
  23. char op=input[index];
  24. vector<int> left=diffWaysToCompute(input.substr(0,index));
  25. vector<int> right=diffWaysToCompute(input.substr(index+1));
  26. if(op=='+'){
  27. for(int i=0;i<left.size();i++){
  28. for(int j=0;j<right.size();j++){
  29. res.push_back(left[i]+right[j]);
  30. }
  31. }
  32. }
  33. else if(op=='-'){
  34. for(int i=0;i<left.size();i++){
  35. for(int j=0;j<right.size();j++){
  36. res.push_back(left[i]-right[j]);
  37. }
  38. }
  39. }
  40. else{
  41. for(int i=0;i<left.size();i++){
  42. for(int j=0;j<right.size();j++){
  43. res.push_back(left[i]*right[j]);
  44. }
  45. }
  46. }
  47. }
  48. return res;
  49. }
  50. };

改进(网上代码):

  1. class Solution {
  2. public:
  3. vector<int> diffWaysToCompute(string input) {
  4. vector<int> res;
  5. for (int i = 0; i < input.size(); ++i) {
  6. if (input[i] == '+' || input[i] == '-' || input[i] == '*') {
  7. vector<int> left = diffWaysToCompute(input.substr(0, i));
  8. vector<int> right = diffWaysToCompute(input.substr(i + 1));
  9. for (int j = 0; j < left.size(); ++j) {
  10. for (int k = 0; k < right.size(); ++k) {
  11. if (input[i] == '+') res.push_back(left[j] + right[k]);
  12. else if (input[i] == '-') res.push_back(left[j] - right[k]);
  13. else res.push_back(left[j] * right[k]);
  14. }
  15. }
  16. }
  17. }
  18. if (res.empty()) res.push_back(stoi(input));
  19. return res;
  20. }
  21. };

发表评论

表情:
评论列表 (有 0 条评论,349人围观)

还没有评论,来说两句吧...

相关阅读