输入一个32位的整数a,使用按位异或^运算,生成一个新的32位整数b,使得该整数b的每一位等于原整数a中该位左右两边两个bit位的异或结果
来源:互联网 发布:男士 护肤品牌 知乎 编辑:程序博客网 时间:2024/05/18 01:09
#include <stdio.h>
int fun(int num);
int main()
{
int num;
{
int num;
printf("Enter your number :\n"); //提示用户输入变量
scanf("%d",&num);
scanf("%d",&num);
printf("The number after function is %d .\n",fun(num)); //调用函数并输出函数返回值
return 0;
}
return 0;
}
int fun(int num)
{
int temp,number = 0xffff; //定义中间变量temp,初始化结果值
int i;
for(i = 0;i < 32; i++) //利用循环对参数进行运算
{
if(i == 0 || i == 31) //对于第一位和最后一位采用不同算法取值
{
temp = (num >> 1) & 0x0000;
}
else //对于其他变量等于其前一位和后一位相与
{
temp = (num >> (i + 1)) & (num >> (i - 1));
}
temp = temp & 0x0001;
if(temp) //对于置位数不同的情况分开考虑
{
temp = (temp << i);
number = number | temp;
}
else
{
temp = ~(1 << i);
number = number & temp;
}
}
return number;
}
{
int temp,number = 0xffff; //定义中间变量temp,初始化结果值
int i;
for(i = 0;i < 32; i++) //利用循环对参数进行运算
{
if(i == 0 || i == 31) //对于第一位和最后一位采用不同算法取值
{
temp = (num >> 1) & 0x0000;
}
else //对于其他变量等于其前一位和后一位相与
{
temp = (num >> (i + 1)) & (num >> (i - 1));
}
temp = temp & 0x0001;
if(temp) //对于置位数不同的情况分开考虑
{
temp = (temp << i);
number = number | temp;
}
else
{
temp = ~(1 << i);
number = number & temp;
}
}
return number;
}
0 0
- 位运算训练05—输入一个32位的整数a,使用按位异或^运算,生成一个新的32位整数b; 使得该整数b的每一位等于原整数a中该位左右两边两个bit位的异或结果
- 输入一个32位的整数a,使用按位异或^运算,生成一个新的32位整数b,使得该整数b的每一位等于原整数a中该位左右两边两个bit位的异或结果
- 输入一个32位的整数a,使用按位异或^运算,生成一个新的32位整数b,使得该整数b的每一位等于原整数a中该位左右两边两个bit位的异或结果
- 5.题目:输入一个32位的整数a,使用按位异或^运算,生成一个新的32位整数b,使得该整数b的每一位等于原整数a中该位左右两边两个bit位的异或结果 提示:0 ^ 0 = 0; 1 ^ 1 = 0;
- 输入个32位的整数a,使用按位异或^运算,生成一个新的32位整数b,使得该整数b的每一位等于原整数a中该位左右两边两个bit位的异或结果
- 输入一个32位的整数啊,使用按位异或运算,生成一个新的32位整数b,使得该整数b的每一位等于原整数a中该位左右两边两个bit位的异或结果
- 位运算训练04—输入一个整数a,再输入两个整数p(p<32),v(0|1);将该整数a的p位设置为v,输出修改后的该整数的二进制表示
- 位运算训练02—输入一个整数a,再输入两个整数p1,p2(p1,p2<32) 输出该整数的二进制表示方法中从右端开始的p1到p2位
- 位运算训练03—输入一个整数a,再输入两个整数p1,p2(p1,p2<32);将该整数的二进制表示方法中从右端开始的p1到p2位取反后输出
- 输入一个整数,输出这个整数的每一位
- 输入一个整数a,再输入两个整数p(p<32),v(0|1),将该整数a的p位设置为v,输出修改后的该整数的二进制表示.
- 4.输入一个整数a,再输入两个整数p(p<32),v(0|1),将该整数a的p位设置为v,输出修改后的该整数的二进制表示.
- 输入一个整数a,再输入两个整数p(p<32),v(0|1),将该整数a的p位设置为v,输出修改后的该整数的二进制表示.
- 获取一个整数的每一位
- 输出一个整数val的每一位
- 输出一个整数的每一位
- 输出一个整数的每一位
- 输出一个整数的每一位
- LightOJ1274(组合数)
- Android MD5
- Spring Boot / Spring MVC 入门实践 (四) :需求记录网站的实现
- 优秀的自学机器学习课程
- 遍历HashMap和ArrayList
- 输入一个32位的整数a,使用按位异或^运算,生成一个新的32位整数b,使得该整数b的每一位等于原整数a中该位左右两边两个bit位的异或结果
- Storm 1.0.2 - 单词计数案例学习
- linux通信 --- 消息队列
- 变换编码增益(Transform Coding Gain)
- CF 4D Mysterious Present
- Windows环境下的NodeJS+NPM+Bower安装配
- 三道找规律的题
- 几种排序总结(一)
- stop(true,true) jQuery多格焦点图效果