输入一个32位的整数a,使用按位异或^运算,生成一个新的32位整数b,使得该整数b的每一位等于原整数a中该位左右两边两个bit位的异或结果
来源:互联网 发布:中国人民大学网络登录 编辑:程序博客网 时间:2024/05/21 12:48
程序要求:输入一个32位的整数a,使用按位异或^运算,生成一个新的32位整数b,使得该整数b的每一位等于原整数a中该位左右两边两个bit位的异或结果
/*****************************************************
copyright (C), 2014-2015, Lighting Studio. Co., Ltd.
File name:
Author:Jerey_Jobs Version:0.1 Date:
Description:
Funcion List:
*****************************************************/
copyright (C), 2014-2015, Lighting Studio. Co., Ltd.
File name:
Author:Jerey_Jobs Version:0.1 Date:
Description:
Funcion List:
*****************************************************/
#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的每一位
- 输出一个整数的每一位
- 输出一个整数的每一位
- 输出一个整数的每一位
- 2016-2017 ACM-ICPC, NEERC, Southern Subregional Contest
- Ubuntu14.04 下 OpenCV3 安装
- <2>tableIsExist
- 客户端axis调用cxf服务端webservice接口问题
- Android 解决多个Fragment切换时不断实例化
- 输入一个32位的整数a,使用按位异或^运算,生成一个新的32位整数b,使得该整数b的每一位等于原整数a中该位左右两边两个bit位的异或结果
- iOS第三方框架的相关问题
- 功课1-GCD的使用
- Type
- 安卓基础之如何显示网络图片
- <3>createTableIfNotExist
- 【腾讯TMQ】测试建模 ——从需求的角度说建模
- REST架构风格简介
- 软件使用技巧