二进制位翻转:

来源:互联网 发布:摩卡监控软件 编辑:程序博客网 时间:2024/06/08 02:35

题目:使用c语言编写函数:

unsigned int reverse_bit(unsigned int value);

这个函数的返回值value的二进制位模式从左到右翻转后的值

思路:

利用按位与(&)求得二进制每一位的数字,然后再与ret 进行 按位或(|)   运算。  ret左移,value右移



//unsigned int reverse_bit(unsigned int value);//二进制位进行翻转#include<stdio.h>#include<stdlib.h>unsigned int reverse_bit(unsigned int value){unsigned int ret = 0;for (int i = 0; i < 32; i++){ret = ret << 1;unsigned bit = value & 1;value =value>> 1;ret |= bit;}return ret;}int main(){unsigned int value = 0;scanf("%d", &value);unsigned int  ret=reverse_bit(value);printf("%u\n", ret);system("pause");return 0;}


1 0
原创粉丝点击