ホームページ > バックエンド開発 > C#.Net チュートリアル > バイナリ表現が回文かどうかをチェックする C# プログラム

バイナリ表現が回文かどうかをチェックする C# プログラム

王林
リリース: 2023-09-13 11:21:08
転載
1336 人が閲覧しました

检查二进制表示形式是否回文的 C# 程序

回文番号を確認するには、数値が 5 で、そのバイナリが −

101
ログイン後にコピー

であると仮定します。101 の回文は 101 であり、確認するには次のようにする必要があります。次の関数を使用してビットを反転します。ここでは、ビット単位の左シフト演算子とビット単位の右シフト演算子が使用されます。-

public static long funcReverse(long num) {
   long myRev = 0;
   while (num > 0) {
      myRev <<= 1;
      if ((num &amp; 1) == 1)
         myRev ^= 1;
      num >>= 1;
   }
   return myRev;
}
ログイン後にコピー

実際の表現は、funcReverse() 関数から値を返して取得することによって、逆の表現と比較されます-

public static bool checkPalindrome(long num) {
   long myRev = funcReverse(num);
   return (num == myRev);
}
ログイン後にコピー

次は、数値のバイナリ表現が回文であるかどうかを確認するための完全な例です -

オンライン デモンストレーション

using System;
public class Demo {
   public static long funcReverse(long num) {
      long myRev = 0;
      while (num > 0) {
         myRev <<= 1;
         if ((num &amp; 1) == 1)
            myRev ^= 1;
         num >>= 1;
      }
      return myRev;
   }
   public static bool checkPalindrome(long num) {
      long myRev = funcReverse(num);
      return (num == myRev);
   }
   public static void Main() {
      // Binary value of 5 us 101
      long num = 5;
      if (checkPalindrome(num))
         Console.WriteLine("Palindrome Number");
      else
         Console.WriteLine("Not a Palindrome Number");
   }
}
ログイン後にコピー

出力

rreeee

以上がバイナリ表現が回文かどうかをチェックする C# プログラムの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:tutorialspoint.com
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート