>  기사  >  백엔드 개발  >  C++에서 1비트 또는 2비트를 변경하여 주어진 두 숫자를 동일하게 만들 수 있는지 확인

C++에서 1비트 또는 2비트를 변경하여 주어진 두 숫자를 동일하게 만들 수 있는지 확인

WBOY
WBOY앞으로
2023-08-25 17:57:101098검색

C++에서 1비트 또는 2비트를 변경하여 주어진 두 숫자를 동일하게 만들 수 있는지 확인

컴퓨터 프로그래밍 분야에서는 많은 작업이 숫자 값을 중심으로 이루어집니다. 어떤 경우에는 몇 비트를 수정하여 두 숫자를 동일하게 만들 수 있는지 확인해야 할 수도 있습니다. 이 문제는 어려움을 초래할 수 있지만 올바른 전략은 성공적인 솔루션으로 이어질 것입니다.

문법

알고리즘에 대한 깊은 이해를 위한 탄탄한 기반을 구축하려면 먼저 이 특정 접근 방식을 사용하여 후속 코딩에 사용되는 구문에 익숙해지도록 하세요.

으아악

주어진 두 정수 num1과 num2가 1비트 또는 2비트만 변경하여 동일하게 만들 수 있는지 확인하기 위해 checkEquality 함수를 사용하여 부울 응답을 생성합니다.

알고리즘

우리 알고리즘의 단계별 분석은 다음과 같습니다.

  • num1과 num2의 XOR 결과를 결정하고 출력을 새 변수 xorResult에 할당합니다.

  • 알고리즘을 사용하여 xorResult에서 설정된 비트 수를 계산하고 결과를 setBitCount라는 변수에 할당합니다.

  • 작업이 성공하려면 setBitCount가 2를 초과할 수 없습니다. 이 경우 우리 함수는 실제 결과를 반환합니다. 이 지정된 임계값을 초과하면 출력이 거짓이라는 결론을 내릴 수 있습니다.

  • 이제 알고리즘이 있으므로 이 문제를 해결하기 위한 최소한 두 가지 다른 방법을 살펴보겠습니다.

방법 1: 비트 연산

이 방법에서는 비트 연산을 사용하여 숫자가 동일하게 될 수 있는지 확인합니다.

으아악

출력

으아악

설명

비트 중 하나 또는 두 개의 값을 수정하여 C++ 코드는 처리 중에 제공된 두 값 사이의 완벽한 정렬이 설정될 수 있는지 확인하기 위한 간단한 검사를 수행합니다. 이 목표를 달성하기 위해 코드의 중요한 부분은 "checkEquality"라는 특수 함수를 정의하는 것입니다. 이 사용자 정의 함수를 사용하려면 두 개의 정수 변수를 입력으로 제공해야 합니다. 이 특정 함수의 출력 유형은 부울 논리를 사용하므로 사용자는 런타임 시 함수에 제공된 인수가 완벽한 수치 정렬에 충분한지 여부를 나타내는 결과를 쉽게 얻을 수 있습니다.

계산 목적으로 이 프로그램은 XOR 알고리즘을 사용하여 checkEquality 메서드를 통해 위의 정수 입력을 비교합니다. 이후 자동으로 저장된 결과는 "xorResult" 변수에 캡처됩니다. 다음 단계의 핵심 요소는 xorResult와 XORResult - 1 사이의 비트별 AND 중간 결과를 계산하는 것입니다. 이 단계에서 반환 값이 "0"인 경우 bitCheck 변수의 가정이 필요해집니다. 이는 필수 조건이 충족되었음을 나타내기 때문에 checkEquality 함수의 요청을 충족하려면 정수 입력의 한두 비트를 변경해야 한다고 가정할 수 있습니다. 완료되면 프로그램은 최종 계산 단계로 checkEquality 메서드에 매개 변수를 전달하기 전에 사용자에게 입력하라는 메시지를 표시합니다. 프로세스가 끝나면 출력 메시지에 필요한 비트 수준 변경 여부가 표시되고 해당 메시지가 콘솔 출력에 표시됩니다. 이 구현은 C++의 비트 단위 조작 및 XOR 활용의 훌륭한 예를 보여줍니다.

방법 2: 해밍 거리 방법

이 방법에서는 해밍 거리(Hamming distance) 개념을 사용하여 문제를 해결하겠습니다.

으아악

출력

으아악

설명

이 예에서는 두 개의 다른 숫자를 동일하게 만들기 위해 하나 또는 두 개의 비트를 변경할 수 있는지 여부를 결정하도록 설계된 C++ 프로그램을 제공합니다. 또한 Kemighan의 알고리즘을 활용하여 정수 값에 존재하는 설정 비트 수를 결정하는 "countSetBits"라는 함수가 있습니다.

checkEquality 함수에서 코드는 두 입력 숫자의 배타적 OR을 계산하고 그 결과를 xorResult에 저장합니다. 이전 문은 countSetBits 함수를 트리거하여 xorResult에 설정된 비트 수를 결정한 다음 setBitCount에 누적됩니다. setBitCount가 2 이하로 결정될 때마다 균형을 이루기 위해 1~2비트만 수정하면 함수가 true를 반환하게 된다는 의미입니다. 그렇지 않으면 false를 반환합니다.

주 기능에서 프로그램은 사용자에게 두 개의 숫자를 입력하라는 메시지를 표시합니다. 그런 다음 사용자가 제공한 번호를 사용하여 checkEquality 함수를 호출하고 결과를 저장합니다. 마지막으로, 결과 값에 따라 프로그램은 1비트 또는 2비트를 변경하여 숫자를 동일하게 만드는 것이 가능한지 여부를 나타내는 적절한 메시지를 인쇄합니다.

이 코드는 XOR 연산과 Kernighan 알고리즘을 활용하여 설정된 비트를 효율적으로 계산하여 문제를 명확하게 구현합니다.

결론

저희 기사에서는 1비트 또는 2비트만 변경하면서 주어진 두 숫자가 같은지 여부를 결정하는 문제를 탐구합니다. 이 문제를 해결하기 위해 우리는 비트 연산 방법과 해밍 거리 방법이라는 두 가지 효과적인 방법을 제안합니다. 두 방법 모두 효율적인 솔루션을 제공합니다. 또한 이러한 방법을 기반으로 실제 실행 가능한 코드 예제도 제공합니다. 이러한 방법을 이해하고 구현하면 몇 비트를 변경하여 두 숫자가 동일하게 될 수 있는지 효과적으로 확인할 수 있습니다.

위 내용은 C++에서 1비트 또는 2비트를 변경하여 주어진 두 숫자를 동일하게 만들 수 있는지 확인의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 tutorialspoint.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제