【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语言中,要交换一个整数的二进制位中的奇数位和偶数位,重点需要理解位操作。

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

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

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

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

相关文章
|
7月前
|
存储 C语言
【C语言】基础刷题训练4(含全面分析和代码改进示例)
【C语言】基础刷题训练4(含全面分析和代码改进示例)
|
5月前
|
机器学习/深度学习 编译器 C语言
C语言刷题(中)(保姆式详解)
C语言刷题(中)(保姆式详解)
33 0
|
7月前
|
C语言
【C语言刷题训练】——第7节(含代码与分析思路)
【C语言刷题训练】——第7节(含代码与分析思路)
|
7月前
|
测试技术 C语言 C++
【C语言刷题训练——6】鹏哥C语言刷题训练营笔记,含代码讲解改进
【C语言刷题训练——6】鹏哥C语言刷题训练营笔记,含代码讲解改进
|
7月前
|
存储 C语言
【C语言】鹏哥C语言刷题训练营——第5节内容笔记(含代码全面分析和改进,讲解)
【C语言】鹏哥C语言刷题训练营——第5节内容笔记(含代码全面分析和改进,讲解)
108 0
|
9月前
|
C语言
C语言刷题(函数)
C语言刷题(函数)
|
9月前
|
C语言
C语言刷题(循环结构程序设计)
C语言刷题(循环结构程序设计)
|
2月前
|
存储 算法 C语言
【C语言程序设计——函数】素数判定(头歌实践教学平台习题)【合集】
本内容介绍了编写一个判断素数的子函数的任务,涵盖循环控制与跳转语句、算术运算符(%)、以及素数的概念。任务要求在主函数中输入整数并输出是否为素数的信息。相关知识包括 `for` 和 `while` 循环、`break` 和 `continue` 语句、取余运算符 `%` 的使用及素数定义、分布规律和应用场景。编程要求根据提示补充代码,测试说明提供了输入输出示例,最后给出通关代码和测试结果。 任务核心:编写判断素数的子函数并在主函数中调用,涉及循环结构和条件判断。
80 23
|
14天前
|
人工智能 Java 程序员
一文彻底搞清楚C语言的函数
本文介绍C语言函数:函数是程序模块化的工具,由函数头和函数体组成,涵盖定义、调用、参数传递及声明等内容。值传递确保实参不受影响,函数声明增强代码可读性。君志所向,一往无前!
16 1
一文彻底搞清楚C语言的函数
|
2月前
|
算法 C语言
【C语言程序设计——函数】利用函数求解最大公约数和最小公倍数(头歌实践教学平台习题)【合集】
本文档介绍了如何编写两个子函数,分别求任意两个整数的最大公约数和最小公倍数。内容涵盖循环控制与跳转语句的使用、最大公约数的求法(包括辗转相除法和更相减损术),以及基于最大公约数求最小公倍数的方法。通过示例代码和测试说明,帮助读者理解和实现相关算法。最终提供了完整的通关代码及测试结果,确保编程任务的成功完成。
97 15