C ++中的括号扩展

假设我们有一个表示单词列表的字符串S。这里单词中的每个字母都有1个或多个选项。如果只有一个选项,则按原样显示字母。如果有多个选项,则用花括号分隔选项。因此,例如,“ {{a,b,c}””将代表选项[“ a”,“ b”,“ c”]。现在,例如,如果输入像“ {a,b,c} d {e,f}”,则它将表示列表[“ ade”,“ adf”,“ bde”,“ bdf”,“ cde”, “ cdf”]。

以字典顺序返回以这种方式可以形成的所有单词。

为了解决这个问题,我们将遵循以下步骤-

  • 定义一个称为ret的数组,定义一个整数类型变量n

  • 定义一个方法solve(),它将采用索引,列表和curr作为输入

  • 如果index = n,则将curr插入ret并返回

  • 对于我来说,范围是0到列表的大小[索引]

    • 调用solve(index + 1,list,curr + list [index,i])

  • 在主要方法中,执行以下操作

  • 创建一个大小为100的列表,设置n:= 0,标志:= false

  • 当我的范围是0到s的大小– 1

    • 如果s [i]是逗号,则跳到下一个迭代

    • 否则,当s [i]打开大括号时,则设置标志:= true

    • 否则,当s [i]关闭大括号时,则将标志:= false设置为n并增加1

    • 否则将list [n]增加s [i],现在如果flag为false,则将n增加1

  • 调用resolve(0,list,空字符串)

  • 排序ret数组

  • 返回ret

让我们看下面的实现以更好地理解-

#include <bits/stdc++.h>

using namespace std;

class Solution {

   public:

   vector <string> ret;

   int n;

   vector<string> expand(string s) {

      vector <string> list(100);

      n = 0;

      int flag = false;

      for(int i = 0; i < s.size(); i++){

         if(s[i] == ','){

            continue;

         }else if(s[i] == '{'){

            flag = true;

         }else if(s[i] == '}'){

            flag = false;

            n++;

         }else{

            list[n] += s[i];

            if(!flag)n++;

         }

      }

      solve(0, list);

      sort(ret.begin(), ret.end());

      return ret;

   }

   void solve(int idx, vector <string> list, string curr = ""){

      if(idx == n){

         ret.push_back(curr);

         return;

      }

      for(int i = 0; i < list[idx].size(); i++){

         solve(idx + 1, list, curr + list[idx][i]);

      }

   }

};

main(){

   Solution ob;

   print_vector(ob.expand("{a,b}c{d,e}f"));

}

输入值

"{a,b}c{d,e}f"

输出结果

[acdf, acef, bcdf, bcef, ]

以上是 C ++中的括号扩展 的全部内容, 来源链接: utcz.com/z/327323.html

回到顶部