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

Cプログラムのバウムスウィートシーケンス?


ここでは、バウムスウィートシーケンスが表示されます。このシーケンスは1つのバイナリシーケンスです。数値nに奇数の連続する0がある場合、n番目のビットは0になり、そうでない場合、n番目のビットは1になります。

自然数nがあります。私たちのタスクは、バウムスウィートシーケンスのn番目の項を見つけることです。したがって、奇数の長さのゼロの連続ブロックがあるかどうかを確認する必要があります。

数値が4の場合、4は100であるため、項は1になります。したがって、ゼロの数は2つ(偶数)になります。

アルゴリズム

BaumSweetSeqTerm(G、s)-

begin
   define bit sequence seq of size n
   baum := 1
   len := number of bits in binary of n
   for i in range 0 to len, do
      j := i + 1
      count := 1
      if seq[i] = 0, then
         for j in range i + 1 to len, do
            if seq[j] = 0, then
               increase count
            else
               break
            end if
         done
         if count is odd, then
            baum := 0
         end if
      end if
   done
   return baum
end
>

#include <bits/stdc++.h>
using namespace std;
int BaumSweetSeqTerm(int n) {
   bitset<32> sequence(n); //store bit-wise representation
   int len = 32 - __builtin_clz(n);
   //builtin_clz() function gives number of zeroes present before the first 1
   int baum = 1; // nth term of baum sequence
   for (int i = 0; i < len;) {
      int j = i + 1;
      if (sequence[i] == 0) {
         int count = 1;
         for (j = i + 1; j < len; j++) {
            if (sequence[j] == 0) // counts consecutive zeroes
               count++;
            else
               break;
         }
         if (count % 2 == 1) //check odd or even
            baum = 0;
      }
      i = j;
   }
   return baum;
}
int main() {
   int n = 4;
   cout << BaumSweetSeqTerm(n);
}

出力

1

  1. Pythonで同等の頻度のシーケンスを見つけるプログラム

    番号のリストがあるとします。シーケンスから番号を削除したときに、各番号が同じ回数発生するように、番号の最長シーケンスの長さを見つける必要があります。 したがって、入力が数値=[2、4、4、7、7、6、6]のような場合、出力は7になります。 これを解決するには、次の手順に従います- num_freq:=新しいマップ freq_freq:=新しいマップ diff_freq:=新しいセット 結果:=1 インデックスIと値num(num)ごとに、実行します cur_freq:=num_freq [num] num_freq [num]:=num_fre

  2. Pythonで最長の連続シーケンスの長さを見つけるプログラム

    並べ替えられていない数値の配列があるとすると、連続する要素の最長シーケンスの長さを見つける必要があります。 したがって、入力がnums =[70、7、50、4、6、5]の場合、連続する要素の最長シーケンスは[4、5、6、7]であるため、出力は4になります。したがって、その長さを返します:4。 これを解決するには、次の手順に従います- nums:=numsのすべての一意の要素 max_cnt:=0 numsのnumごとに、実行します num-1がnumsにない場合、 cnt:=0 numがnumsに存在する間、実行します num:=num + 1