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
-
階段の数と各階段のステップ数をカウントする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
-
サイズ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