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

C++で文字列の一意のサブシーケンスの数をカウントするプログラム


文字列sがあるとすると、sの空でない一意のサブシーケンスの数を見つける必要があります。答えが非常に大きい場合は、結果を10 ^ 9+7で変更します。

したがって、入力がs ="xxy"の場合、出力は5になります。これは、 "x"、 "xx"、 "xy"、 "y"、および"xxy"の5つのサブシーケンスがあるためです。

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

  • m:=10 ^ 9 + 7

  • n:=sのサイズ

  • サイズ26の配列テーブルを定義する

  • res:=0

  • 初期化i:=1の場合、i <=nの場合、更新(iを1増やします)、do-

    • c:=s [i − 1] −'a'のASCII

    • curr:=(res + 1 − table [c] + m)mod m

    • res:=(res + curr)mod m

    • table [c]:=(table [c] + curr)mod m

  • 解像度を返す

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

#include <bits/stdc++.h>
using namespace std;
const int m = 1e9 + 7;
int solve(string s) {
   int n = s.size();
   vector<int> table(26);
   long long res = 0;
   for (int i = 1; i <= n; ++i) {
      int c = s[i − 1] − 'a';
      int curr = (res + 1 − table[c] + m) % m;
      res = (res + curr) % m;
      table[c] = (table[c] + curr) % m;
   }
   return res;
}
int main(){
   string s = "xxy";
   cout << solve(s);
}

入力

"xxy"

出力

5

  1. 階段の数と各階段のステップ数をカウントするC++プログラム

    n個の要素を持つ配列Aがあるとします。アマルが高層ビルの階段を上っていくようにしましょう。登るたびに、1から数え始めます。たとえば、3段と4段の2つの階段を上る場合、1、2、3、1、2、3、4のような数字を話します。配列Aでは、数字はアマルが言った階段の数字を表しています。彼が登った階段の数を数え、各階段の階段の数も印刷する必要があります。 したがって、入力がA =[1、2、3、1、2、3、4、5]の場合、出力は2、[3、5]になります。 ステップ これを解決するには、次の手順に従います- p = 0 n := size of A for initialize i := 0, when i

  2. サイズdで作成できる十二角形の数をカウントするC++プログラム

    数dがあるとします。正方形のタイルと辺の長さが1の通常の三角形のタイルが無数にあると考えてください。これらのタイルを使用して、側面dの通常の十二角形(12辺の多角形)を形成できる方法をいくつ見つける必要があります。答えが大きすぎる場合は、結果mod998244353を返します。 ステップ これを解決するために、次の手順に従います- b := floor of d/2 - 1 c := 1 for initialize i := 2, when i < d, update (increase i by 1), do:    b := b * (floor of