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

C++の3文字すべてを含む部分文字列の数


文字a、b、cのみで構成される文字列sを指定したとします。これらすべての文字a、b、およびcが少なくとも1回出現する部分文字列の数を返す必要があります。したがって、たとえば、文字列が「abcabc」の場合、出力は10になります。これは、文字a、b、およびcの少なくとも1つのオカレンスを含むサブ文字列であり、これらは「abc」、「abca」、「abcab」、 「abcabc」、「bca」、「bcab」、「cab」、「cabc」、「abc」(これも最後の部分です)。

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

  • ret:=0、mというマップを作成し、j:=0

    を設定します。
  • 0からsのサイズまでの範囲のiの場合

    • マップmのs[i]の数を増やす

    • 一方、m [‘a’]>0かつm[‘b’]>0かつm[‘c’]> 0、

      • マップmのs[i]の数を減らします

      • jを1増やします

    • retをj増やす

  • retを返す

例(C ++)

理解を深めるために、次の実装を見てみましょう-

#include <bits/stdc++.h>
using namespace std;
class Solution {
public:
   int numberOfSubstrings(string s) {
      int ret = 0;
      map <char, int> m;
      int j = 0;
      for(int i = 0; i < s.size(); i++){
         m[s[i]]++;
         while(m['a'] > 0 && m['b'] > 0 && m['c'] > 0){
            m[s[j]]--;
            j++;
         }
         ret += j;
      }
      return ret;
   }
};
main(){
   Solution ob;
   cout << (ob.numberOfSubstrings("abcabc"));
}

入力

"abcabc"

出力

10

  1. C++の整数の文字列で6で割り切れる部分文字列の数

    整数文字列が与えられ、整数形式で6で割り切れる部分文字列の数を決定する必要がある問題を見ていきます。入力は、数値(整数)で構成される文字列の形式であることに注意してください。それでも、分割可能性チェックは整数のみと見なして実行されます(文字列入力のASC​​II値は使用されません)。 入力 str = “648” 出力 説明 サブストリング「6」、「48」、および「648」は6で割り切れる。 入力 str = “38342” 出力 4 説明 サブストリング「3834」、「342」、「834」、および「42」は6で割り切

  2. C++を使用して文字列の部分文字列の数を見つける

    この記事では、特定の文字列に形成できるサブ文字列(空ではない)の数を見つけるためのアプローチについて学習します。 Input : string = “moon” Output : 10 Explanation: Substrings are ‘m’, ‘o’, ‘o’, ‘n’, ‘mo’, ‘oo’, ‘on’, ‘moo’, ‘oon’ and &