C++の特定の範囲でAまたはBの約数の合計をカウントします
4つの整数L、R、A、Bが与えられます。目標は、AまたはB、あるいはその両方を完全に分割する範囲[L、R]の数値の数を見つけることです。
これを行うには、LからRにトラバースし、数値ごとにnumber%A ==0またはnumber%B ==0の場合、除数のカウントをインクリメントします。
例を挙げて理解しましょう。
入力 − L =10、R =15、A =4、B =3
出力 −AまたはBの約数の数− 2
説明 −
Number 12 is fully divisible by 3 and 4. Number 15 is fully divisible by 3 only. Total divisors=2
入力 − L =20、R =30、A =17、B =19
出力 − AまたはBの約数の数− 0
説明 − AまたはB、あるいはその両方で完全に割り切れる20から30までの数字はありません。
以下のプログラムで使用されているアプローチは次のとおりです
-
4つの変数A、B、L、Rを取りました。
-
関数countDivisors(int l、int r、int a、int b)はすべてを入力として受け取り、範囲[L、R]にあるAまたはB、あるいはその両方の除数を返します。
-
初期カウントを0とします。
-
i=Lからi=Rまで、i%a ==0またはi%b==0の増分カウントの場合。
-
ループの終わりに、AまたはBの約数としてカウントします。
-
結果としてカウントを返します。
例
#include <bits/stdc++.h>
using namespace std;
int countDivisors(int l, int r, int a,int b){
int count = 0;
for (int i = l; i <= r; i++){
if(i%a==0 || i%b==0)
{ count++ ; }
}
return count;
}
int main(){
int L=5;
int R=15;
int A=2;
int B=5;
cout <<endl<< "Total divisors of A and B : "<<countDivisors(L,R,A,B);
return 0;
} 出力
上記のコードを実行すると、次の出力が生成されます-
Total divisors of A and B : 7
-
C++の特定の文字列内のすべてのパリンドロームサブシーケンスをカウントします
このチュートリアルでは、特定の文字列内のすべてのパリンドロームサブシーケンスの数を見つけるプログラムについて説明します。 このために、文字列が提供されます。私たちのタスクは、その特定の文字列で作成できるパリンドロームサブシーケンスの数を見つけることです。 例 #include<iostream> #include<cstring> using namespace std; //returning total palindromic sequence int count_palin(string str){ int N = str.length
-
C++で指定されたXORを持つすべてのペアをカウントします
このチュートリアルでは、指定されたXORのペアの数を見つけるプログラムについて説明します。 このために、配列と値が提供されます。私たちのタスクは、XORが指定された値に等しいペアの数を見つけることです。 例 #include<bits/stdc++.h> using namespace std; //returning the number of pairs //having XOR equal to given value int count_pair(int arr[], int n, int x){ int result = 0; &