【C语言刷题系列】交换整数的奇数位和偶数位

简介: 【C语言刷题系列】交换整数的奇数位和偶数位

 

一、问题描述

使用C语言代码实现:将一个整数的奇数位和偶数位交换

二、解决思路

在C语言中,要交换一个整数的二进制位中的奇数位和偶数位,重点需要理解位操作

当我们谈论二进制位的奇数位和偶数位时,我们是指从右到左(或从最低位到最高位)数的位置。在这种计数方式下,第一位是奇数位,第二位是偶数位,依此类推。

    1. 首先,分别取出奇数位和偶数位,(此处默认整数是4字节,也就是32位二进制位)

  • 将整数与01010101010101010101010101010101(写成十六进制是0x55555555)进行按位与&运算,即可得到原整数的奇数位
  • 将整数与10101010101010101010101010101010(写成十六进制是0xaaaaaaaa)进行按位与&运算,即可得到原整数的偶数位

 

     2. 然后,将奇数位和偶数位的位置边换

  • 将上一步得到的整数的奇数位,左移<<一位,即可将奇数位变换到偶数位的位置上
  • 将上一步得到的整数的偶数位,右移>>一位,即可将奇数位变换到偶数位的位置上

 

    3. 上一步分别左移右移之后,将奇数位和偶数位变换了位置,接下来将两个结果进行按位或 | 运算,即可将奇数位和偶数位合并在一起,完成转换

 

三、函数实现

#include<stdio.h>
int Exchange(int n)
{
  int a = n & 0x55555555;
  int b = n & 0xaaaaaaaa;
  a <<= 1;
  b >>= 1;
  return (a | b);
}
int main()
{
  int a = 11;
  int b = 13;
  printf("%d\n", Exchange(a));
  printf("%d\n", Exchange(b));
  return 0;
}

 

四、宏实现

#include<stdio.h>
#define Exchange(n) ((((n)&0x55555555)<<1)| (((n)&0xaaaaaaaa)>>1))
int main()
{
  int a = 11;
  int b = 13;
  printf("%d\n", Exchange(a));
  printf("%d\n", Exchange(b));
 
  return 0;
}

 

五、总结

在C语言中,要交换一个整数的二进制位中的奇数位和偶数位,重点需要理解位操作。

使用函数和宏都可以实现该代码。对于此类较短较简单的代码,因为宏只是简单的文本替换,所以省去了函数调用和返回的时间和空间开销,所以效率更高一些

不过要注意的一点是,因为宏是文本替换,所以运算时可以会因为优先级导致一些问题,保险起见,需要在可以会出现问题的表达式两边都加上括号

  个人主页:    倔强的石头的博客

(关注作者,获取更多有趣实用的编程知识哦)

相关文章
|
3月前
|
存储 C语言
【C语言】基础刷题训练4(含全面分析和代码改进示例)
【C语言】基础刷题训练4(含全面分析和代码改进示例)
|
1月前
|
机器学习/深度学习 编译器 C语言
C语言刷题(中)(保姆式详解)
C语言刷题(中)(保姆式详解)
14 0
|
3月前
|
C语言
【C语言刷题训练】——第7节(含代码与分析思路)
【C语言刷题训练】——第7节(含代码与分析思路)
|
3月前
|
测试技术 C语言 C++
【C语言刷题训练——6】鹏哥C语言刷题训练营笔记,含代码讲解改进
【C语言刷题训练——6】鹏哥C语言刷题训练营笔记,含代码讲解改进
|
3月前
|
存储 C语言
【C语言】鹏哥C语言刷题训练营——第5节内容笔记(含代码全面分析和改进,讲解)
【C语言】鹏哥C语言刷题训练营——第5节内容笔记(含代码全面分析和改进,讲解)
|
5月前
|
C语言
C语言刷题(函数)
C语言刷题(函数)
|
5月前
|
C语言
C语言刷题(循环结构程序设计)
C语言刷题(循环结构程序设计)
|
1月前
|
C语言 C++
C语言 之 内存函数
C语言 之 内存函数
33 3
|
6天前
|
C语言
c语言调用的函数的声明
被调用的函数的声明: 一个函数调用另一个函数需具备的条件: 首先被调用的函数必须是已经存在的函数,即头文件中存在或已经定义过; 如果使用库函数,一般应该在本文件开头用#include命令将调用有关库函数时在所需要用到的信息“包含”到本文件中。.h文件是头文件所用的后缀。 如果使用用户自己定义的函数,而且该函数与使用它的函数在同一个文件中,一般还应该在主调函数中对被调用的函数做声明。 如果被调用的函数定义出现在主调函数之前可以不必声明。 如果已在所有函数定义之前,在函数的外部已做了函数声明,则在各个主调函数中不必多所调用的函数在做声明
21 6
|
26天前
|
存储 缓存 C语言
【c语言】简单的算术操作符、输入输出函数
本文介绍了C语言中的算术操作符、赋值操作符、单目操作符以及输入输出函数 `printf` 和 `scanf` 的基本用法。算术操作符包括加、减、乘、除和求余,其中除法和求余运算有特殊规则。赋值操作符用于给变量赋值,并支持复合赋值。单目操作符包括自增自减、正负号和强制类型转换。输入输出函数 `printf` 和 `scanf` 用于格式化输入和输出,支持多种占位符和格式控制。通过示例代码详细解释了这些操作符和函数的使用方法。
34 10