C ++
 Computer >> コンピューター >  >> プログラミング >> C ++

C++でのブレース拡張


単語のリストを表す文字列Sがあるとします。ここで、単語の各文字には1つ以上のオプションがあります。オプションが1つしかない場合、文字はそのまま表示されます。複数のオプションがある場合は、中括弧でオプションを区切ります。したがって、たとえば、「{a、b、c}」はオプション["a"、 "b"、"c"]を表します。たとえば、入力が「{a、b、c} d {e、f}」の場合、これはリスト["ade"、 "adf"、 "bde"、 "bdf"、 "cde"、 "cdf"]。

この方法で形成できるすべての単語を辞書式順序で返します。

これを解決するには、次の手順に従います-

  • retという配列を定義し、整数型変数nを定義します

  • メソッドsolve()を定義します。これは、入力としてindex、list、currを取ります

  • index =nの場合、currをretに挿入して戻ります

  • 0からlist[index]

    のサイズまでの範囲のiの場合
    • 呼び出しsolve(index + 1、list、curr + list [index、i])

  • メインの方法から、次のようにします

  • サイズ100のリストを作成し、n:=0、フラグ:=falseを設定します

  • 0からsのサイズまでの範囲のiの場合– 1

    • s [i]がコンマの場合、次の反復にスキップします

    • それ以外の場合、s [i]が中括弧を開いているときに、フラグを設定します:=true

    • それ以外の場合、s [i]が中括弧を閉じるときは、フラグ:=falseを設定し、nを1増やします

    • それ以外の場合は、list[n]をs[i]増やします。ここで、フラグがfalseの場合は、nを1増やします

  • 呼び出しsolve(0、リスト、空の文字列)

  • 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, ]

  1. C++での質素な数

    この問題では、正の整数Nが与えられます。私たちのタスクは、与えられた数が質素な数であるかどうかをチェックするプログラムを作成することです。 不正な番号 −指定された数の素因数分解の桁数よりも厳密に桁数が多い数。 例 − 625、数625の素因数は5 4です。 。 625の桁数は3です。 5 4の桁数 は2です。 3は厳密に2より大きくなります。したがって、625は質素な数です。 最初のいくつかの質素な数は − 125、128、243、256、343、512、625など。 問題を理解するために例を見てみましょう Input: n = 128 Output: Frugal n

  2. C++五胞体数

    五胞体数は、パスカルの三角形の5番目の数として表されます。ご存知のように、これは5番目の数字です。つまり、パスカルの三角形に少なくとも5つの数字が必要です。したがって、このシリーズの最初の数字は 1 4 6 4 1から始まります。 パスカルの三角形の4行目。したがって、このチュートリアルでは、たとえば、n番目の五胞体数を見つける必要があります Input : 1 Output : 1 Input : 4 Output : 35 次の図から出力を確認できます- この問題については、可能な限り、これは一種のシリーズであるため、ソリューションでこのシリーズのパターンを見つけようと