C ++
 Computer >> コンピューター >  >> プログラミング >> C ++

C++での右端のセットビットの位置


この問題では、数値Nが与えられます。私たちのタスクは、数値の右端のセットビットのインデックスを出力することです。

問題を理解するために例を見てみましょう

入力 − 4

出力 − 3

説明 − 4の2進数は100、右端のセットビットのインデックスは3です。

この問題を解決するための簡単な解決策は、設定されたビットに遭遇するまで数値をシフトすることですが、数値が大きい場合、これには多くの計算が必要になる可能性があります。

より効率的な解決策は、ブール代数を使用することです。このために、最初に数値の2の補数を計算します。これにより、数値のすべてのビットが反転し、最初の設定ビットがそのままになります。次に、ビット単位の&数を計算します。これは2の補数です。これにより、1つのセットビットと必要な位置のみの数値が得られます。解は+1のlog2で与えられます。

これを理解するには少し複雑に思えます。この方法を使用して例を解いてみましょう。

N= 10 , binary = 1010
2’s complement, 0101
1010 & 0101 = 0010
log2(2) = 1
1+1 = 2 which is the given index.

ソリューションの実装を示すプログラム

#include <iostream>
#include <math.h>
using namespace std;
void rightSetBit(int N) {
   int bitIndex = log2(N & -N)+1;
   cout<<bitIndex;
}
int main() {
   int N = 10;
   cout<<"The rightmost Set bit of the number "<<N<<" is : ";
   rightSetBit(N);
   return 0;
}

出力

The rightmost Set bit of the number 10 is : 2

  1. 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

  2. C++五胞体数

    五胞体数は、パスカルの三角形の5番目の数として表されます。ご存知のように、これは5番目の数字です。つまり、パスカルの三角形に少なくとも5つの数字が必要です。したがって、このシリーズの最初の数字は 1 4 6 4 1から始まります。 パスカルの三角形の4行目。したがって、このチュートリアルでは、たとえば、n番目の五胞体数を見つける必要があります Input : 1 Output : 1 Input : 4 Output : 35 次の図から出力を確認できます- この問題については、可能な限り、これは一種のシリーズであるため、ソリューションでこのシリーズのパターンを見つけようと