ボックスを選択してすべての石を削除できることを確認するC++プログラム
N個の要素を持つ配列Aがあるとします。 N個のボックスがあり、それらが円形に配置されているとします。 i番目のボックスにはA[i]の石が含まれています。次の操作を繰り返し実行して、ボックスからすべての石を取り除くことができるかどうかを確認する必要があります。ボックスを選択します。 1からNの範囲のjごとに、(i + j)番目のボックスから正確にj個の石を削除します。ここで、(N + k)番目のボックスはk番目のボックスと呼ばれます。ボックスに十分な数の石が含まれていない場合、この操作は実行できません。
したがって、入力がA =[4、5、1、2、3]の場合、2番目のボックスから開始することですべての石を取り除くことができるため、出力はTrueになります。
これを解決するには、次の手順に従います-
n := size of A Define an array a of size (n + 1) Define an array b of size (n + 1) sum := 0, p := n * (n + 1) for initialize i := 1, when i <= n, update (increase i by 1), do: a[i] := A[i - 1] sum := sum + a[i] if sum mod p is not equal to 0, then: return false k := sum / p for initialize i := 1, when i <= n, update (increase i by 1), do: b[i] := a[i] - a[(i mod n) + 1] sum := 0 for initialize i := 1, when i <= n, update (increase i by 1), do: a[i] := b[i] sum := sum + a[i] if sum is not equal to 0, then: return false for initialize i := 1, when i <= n, update (increase i by 1), do: if (a[i] + k) mod n is not equal to 0 or a[i] + k < 0, then: return false return true
例
理解を深めるために、次の実装を見てみましょう-
#include <bits/stdc++.h> using namespace std; bool solve(vector<int> A) { int n = A.size(); vector<int> a(n + 1); vector<int> b(n + 1); int sum = 0, p = n * (n + 1) / 2; for (int i = 1; i <= n; i++) { a[i] = A[i - 1]; sum += a[i]; } if (sum % p != 0) { return false; } int k = sum / p; for (int i = 1; i <= n; i++) { b[i] = a[i] - a[i % n + 1]; } sum = 0; for (int i = 1; i <= n; i++) { a[i] = b[i]; sum += a[i]; } if (sum != 0) { return false; } for (int i = 1; i <= n; i++) { if ((a[i] + k) % n != 0 || a[i] + k < 0) { return false; } } return true; } int main(){ vector<int> A = { 4, 5, 1, 2, 3 }; cout << solve(A) << endl; }
入力
{ 4, 5, 1, 2, 3 }
出力
1
-
C++で配列のビットノイズをチェックするプログラム
N個の整数の配列arr[N]が与えられた場合、タスクは、与えられた配列がバイトニックであるかどうかをチェックすることです。指定されたアレイがバイトニックである場合は、「はい、バイトニックアレイです」と出力します。そうでない場合は、「いいえ、バイトニックアレイではありません」と出力します。 Bitonicアレイとは、アレイが最初に厳密に昇順で、次に厳密に降順である場合です。 この配列のように、arr [] ={1、2、3、4、2、-1、-5}はバイトニック配列です。これは、4までは厳密に昇順であり、4以降は厳密に降順であるためです。 入力 arr[] = {1, 3, 5, 4,
-
C++で対合行列をチェックするプログラム
行列M[r][c]が与えられた場合、「r」は行数を示し、「c」はr=cが正方行列を形成するような列数を示します。与えられた正方行列が対合行列であるかどうかを確認する必要があります かどうか。 対合行列 行列は非自発的と呼ばれます 行列がそれ自体と乗算され、その結果が単位行列である場合に限り、行列。行列Iは、その主対角線が1であり、主対角線以外の要素がゼロである場合にのみ、単位行列です。したがって、行列は対合行列であると言えます。 M * M =Iの場合のみ 、ここで M はいくつかの行列であり、私は単位行列です。 以下の例のように- ここで、行列にそれ自体を乗算すると、結果は単