C ++では、係数が最小の範囲内のすべての数値をKとしてカウントします。
このチュートリアルでは、係数がKとして最小の範囲の数値を見つけるプログラムについて説明します。
このために、範囲[a、b]が提供されます。私たちのタスクは、与えられた範囲内で、係数がKとして最小である数を数えることです。
例
#include <bits/stdc++.h> using namespace std; //checking if K is a prime bool if_prime(int k){ if (k <= 1) return false; for (int i = 2; i < k; i++) if (k % i == 0) return false; return true; } //checking if any number is divisible by K int check(int num, int k){ int flag = 1; for (int i = 2; i < k; i++) { if (num % i == 0) flag = 0; } if (flag == 1) { if (num % k == 0) return 1; else return 0; } else return 0; } //counting the possible numbers int findCount(int a, int b, int k){ int count = 0; if (!if_prime(k)) return 0; else { int ans; for (int i = a; i <= b; i++) { ans = check(i, k); if (ans == 1) count++; else continue; } } return count; } int main(){ int a = 2020, b = 6300, k = 29; cout << findCount(a, b, k); return 0; }
出力
28
-
C++のすべての最も深いノードを持つ最小のサブツリー
ルートをルートとする二分木があるとすると、各ノードの深さはルートまでの最短距離です。ここで、ノードは、ツリー全体のノードの中で可能な限り最大の深さを持っている場合に最も深くなります。ノードのサブツリーは、そのノードと、そのノードのすべての子孫のセットです。サブツリー内の最も深いノードがすべて含まれるように、最大の深さのノードを見つける必要があります。したがって、ツリーが次のような場合- その場合、最も深いサブツリーは-になります これを解決するには、次の手順に従います- ソルブ()と呼ばれるメソッドを定義します。これは入力としてルートになります ルートがnull
-
C++で最大の連続する偶数の数を見つけます
n個の要素を持つ配列Aがあるとします。与えられた配列内の連続する偶数の最大数を見つける必要があります。したがって、配列がA =[1、2、3、4、6、8、7]のような場合、カウントは3になります。 これは簡単に解決できます。 2つのカウント変数が必要です。1つはmax_currentで、もう1つはmax_till_nowです。偶数が見つかった場合は、max_currentを増やしてから、max_till_nowと比較します。奇数の要素が見つかるたびに、max_countを0にリセットします。 例 #include<iostream> using namespace std; int