首页 > 后端开发 > C++ > 交换每两个字节中的每两个位

交换每两个字节中的每两个位

WBOY
发布: 2023-09-11 23:01:02
转载
1456 人浏览过

交换每两个字节中的每两个位

在本文中,我们将讨论交换给定数字中的每个交替位的代码解决方案,并返回结果数字。我们将使用位操作的概念来解决这个问题,以在不使用任何循环的情况下以恒定时间解决问题。

Problem statement − We are given a number n, we have to swap the pair of bits that are adjacent to each other.

In other words, we have to swap every odd placed bit with its adjacent even placed bit.

Constrain: While solving the problem, we have to keep In mind that we cannot use a loop for this problem, we have to execute our code in O(1) time complexity only.

Example

Input − n = 10011110

输出 - 在交换偶数位置位和奇数位置位之后,

the binary number obtained is: 01101101

Input − n = 10011110

输出 - 在交换偶数位置位和奇数位置位之后,

the binary number obtained is: 01101101

Explanation

让我们考虑前面的例子以更好地理解。

n = 10011110
Even position bits in n are E – 1 x 0 x 1 x 1 x
Odd position bits in n are O – x 0 x 1 x 1 x 0
登录后复制

For the result, we want the even position bits at the odd position and vice-versa

For even position bits at odd position,

We need to right shift the even position by one position.

因此,对于偶数位置的位,我们只需将 E >> 1 来获取所需的位置。

Similarly, we have to left shift the odd position bits by one position to get the desired position of odd bits.

所以,对于奇数位,我们只需要将O << 1以获取所需的位置。

Now the next problem is to extract the odd and even position bits.

正如我们所知,

0x55 = 01010101 in which every only odd position bits are set ( non 0 ).
0xAA = 10101010 in position bits are set. which, only odd
登录后复制

Hence to extract E from n, we just need to perform

E = n & 0xAA
登录后复制

Similarly, to extract O from n, we need to perform-

O = n & 0x55
登录后复制

Now, to find the swapped output,

步骤

涉及的步骤为-

  • E >> 1

  • O << 1

  • Now, we combine E and O using or operation.

  • Hence our result will be – Result = ( E >> 1 | O << 1 )

Example

的中文翻译为:

示例

这种方法的代码表示如下:

#include<bits/stdc++.h>
using namespace std;
unsigned int swapbits(unsigned int n) {
   unsigned int E = n & 0xAA ;
   unsigned int O = n & 0x55 ;
   unsigned int result = (E >> 1)|(O << 1);
   return result;
}
int main() {
   unsigned int n = 14;
   cout << "After swapping the even position bits with off position bits, the binary number obtained is " << swapbits(n) << endl;
   return 0;
   // code is contributed by Vaishnavi tripathi
}
登录后复制

Output

After swapping the even position bits with off position bits, the binary number obtained is 13
登录后复制

时间复杂度 - 这种方法的时间复杂度为O(1)。

空间复杂度 - 我们没有使用任何额外的空间。辅助空间复杂度为O(1)。

以上是交换每两个字节中的每两个位的详细内容。更多信息请关注PHP中文网其他相关文章!

相关标签:
来源:tutorialspoint.com
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板