회문을 확인하기 위해 숫자가 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"); } }
출력
Palindrome Number