回文番号を確認するには、数値が 5 で、そのバイナリが −
101
であると仮定します。101 の回文は 101 であり、確認するには次のようにする必要があります。次の関数を使用してビットを反転します。ここでは、ビット単位の左シフト演算子とビット単位の右シフト演算子が使用されます。-
public static long funcReverse(long num) { long myRev = 0; while (num > 0) { myRev <<= 1; if ((num & 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 & 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"); } }
以上がバイナリ表現が回文かどうかをチェックする C# プログラムの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。