/********************************************************************************************
* Module Name :位操作;
* Module versions :模块版本;
* Module Date :2016/08/18;
* Student :007;
* Description :说明书;
* Others :合作其他人;
* Revision History :修订历史;
********************************************************************************************/
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
int power(int iNum, int iCnt);
void Reverse(char *pc);
int BinToDec(const char *pcBin);
char *DecToBinR(int iDec, char *pcBin);
char *DecToBin(int iDec, char *pcBin);
int main()
{
char acBuf[256] = { 0 };
int iNum = 0;
char Key = 0xab;
printf("将0xff加密:%#x\n",0xff^Key);
printf("将0xff解密:%#x\n", 0xff ^ Key^Key);
while (1)
{
//printf("请输入二进制字符串:\n");
//scanf("%s", acBuf);
//printf("十进制:%d\n", BinToDec(acBuf));
printf("请输入十进制数:\n");
scanf("%d", &iNum);
DecToBin(iNum, acBuf);
Reverse(acBuf);
printf("二进制:%s\n", DecToBin(iNum, acBuf));
}
/*
所有的位运算,都是指的二进制运算,也就是运算之前,都要转换成二进制才能体现
<<:把所有的位往左移1位
>>:把所有的位往右移1位
&:0&0=0 0&1=0 1&1=1 &0为0 &1不变 把某一位置0 把第3为置0,其他位不变 &1111 1011 ~(1<<3)
|:0|0=0 0|1=1 1|1=1 |1为1 |0不变 把某一位置1 把第3为置1,其他位不变 &0000 0100 1<<3
~:~0=1 ~1=0
^:0^0=0 0^1=1 1^1=0 异或本身=0 A^A=0 异或0不变 A^B^B=A^0=A 轻量级加密算法
*/
system("pause");
return 0;
}
/*=========================
* Function : BinToDec
* Description : 二进制转十进制
* Input Para :二进制字符串
* Output Para :无
* Return Value:十进制结果
===========================*/
int BinToDec(const char *pcBin)
{
int i,iLen = 0,iResult=0;
iLen = strlen(pcBin);
for (i = 0; i < iLen;i++)
{
if (pcBin[iLen-i-1] == '1')
{
iResult += power(2, i);
}
}
return iResult;
}
/*=========================
* Function : power
* Description : 求iNum的iCnt次方
* Input Para :int iNum, int iCnt
* Output Para :无
* Return Value:结果
===========================*/
int power(int iNum, int iCnt)
{
int i,iResult=1;
for (i = 0; i < iCnt; i++)
{
iResult = iResult*iNum;
}
return iResult;
}
/*=========================
* Function : DecToBin
* Description : 十进制转二进制
* Input Para :十进制数
* Output Para :二进制数
* Return Value:二进制数
===========================*/
char *DecToBin(int iDec, char *pcBin)
{
DecToBinR(iDec, pcBin);
Reverse(pcBin);
return pcBin;
}
char *DecToBinR(int iDec, char *pcBin)
{
char *pcAdress = pcBin;
if (pcBin == NULL)
{
return NULL;
}
while (1)
{
*pcBin = iDec % 2 + '0';
printf("*pcBin=%c\n", *pcBin);
iDec = iDec / 2;
if (iDec == 0)
{
break;
}
pcBin++;
}
*(pcBin + 1) = '\0';
return pcAdress;
}
void Reverse(char *pc)
{
int i, iLen = 0;
char t;
iLen = strlen(pc);
for (i = 0; i < iLen / 2; i++)
{
t = pc[i];
pc[i] = pc[iLen-i-1];
pc[iLen - i-1] = t;
}
}
14.位操作
最新推荐文章于 2022-04-24 21:21:57 发布