C++のSquareful配列の数
正の整数の配列Aがあるとすると、隣接する要素のすべてのペアについて、それらの合計が完全な正方形である場合、配列は平方であると言えます。二乗であるAの順列の数を見つける必要があります。 2つの順列A1とA2は、A1[i]がA2[i]と同じではないようなインデックスiがある場合にのみ、同じにはなりません。
したがって、入力が[3,30,6]の場合、[3,6,30]、[30,6,3]のような2つの順列があるため、出力は2になります。
これを解決するには、次の手順に従います-
-
関数isSqr()を定義します。これにはnが必要です。
-
x:=nの平方根
-
(x * x)がn
と同じ場合にtrueを返します
-
-
関数solve()を定義します。これは、配列a、idx、
を取ります。-
idxがaのサイズと同じ場合、-
-
(カウントを1つ増やします)
-
戻る
-
-
訪問した1セットを定義する
-
初期化i:=idxの場合、i
-
(idxが0またはisSqr(a [idx-1] + a [i]))と同じであり、a [i]が訪問されていない場合、-
-
swap(a [idx]、a [i])
-
解決(a、idx + 1)
-
swap(a [idx]、a [i])
-
訪問先にa[i]を挿入
-
-
-
-
メインの方法から、次のようにします-
-
カウント:=0
-
解決(a、0)
-
返品数
理解を深めるために、次の実装を見てみましょう-
例
#include <bits/stdc++.h> using namespace std; typedef long long int lli; class Solution { public: int count; bool isSqr(lli n){ lli x = sqrt(n); return x * x == n; } void solve(vector<int>& a, int idx){ if (idx == a.size()) { count++; return; } set<int> visited; for (int i = idx; i < a.size(); i++) { if ((idx == 0 || isSqr(a[idx - 1] + a[i])) && !visited.count(a[i])) { swap(a[idx], a[i]); solve(a, idx + 1); swap(a[idx], a[i]); visited.insert(a[i]); } } } int numSquarefulPerms(vector<int>& a){ count = 0; solve(a, 0); return count; } }; main(){ Solution ob; vector<int> v = {3,30,6}; cout << (ob.numSquarefulPerms(v)); }
入力
{3,30,6}
出力
2
-
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
-
C++五胞体数
五胞体数は、パスカルの三角形の5番目の数として表されます。ご存知のように、これは5番目の数字です。つまり、パスカルの三角形に少なくとも5つの数字が必要です。したがって、このシリーズの最初の数字は 1 4 6 4 1から始まります。 パスカルの三角形の4行目。したがって、このチュートリアルでは、たとえば、n番目の五胞体数を見つける必要があります Input : 1 Output : 1 Input : 4 Output : 35 次の図から出力を確認できます- この問題については、可能な限り、これは一種のシリーズであるため、ソリューションでこのシリーズのパターンを見つけようと