14.位操作

/********************************************************************************************
* 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;
}
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
编译原理是计算机专业的一门核心课程,旨在介绍编译程序构造的一般原理和基本方法。编译原理不仅是计算机科学理论的重要组成部分,也是实现高效、可靠的计算机程序设计的关键。本文将对编译原理的基本概念、发展历程、主要内容和实际应用进行详细介绍编译原理是计算机专业的一门核心课程,旨在介绍编译程序构造的一般原理和基本方法。编译原理不仅是计算机科学理论的重要组成部分,也是实现高效、可靠的计算机程序设计的关键。本文将对编译原理的基本概念、发展历程、主要内容和实际应用进行详细介绍编译原理是计算机专业的一门核心课程,旨在介绍编译程序构造的一般原理和基本方法。编译原理不仅是计算机科学理论的重要组成部分,也是实现高效、可靠的计算机程序设计的关键。本文将对编译原理的基本概念、发展历程、主要内容和实际应用进行详细介绍编译原理是计算机专业的一门核心课程,旨在介绍编译程序构造的一般原理和基本方法。编译原理不仅是计算机科学理论的重要组成部分,也是实现高效、可靠的计算机程序设计的关键。本文将对编译原理的基本概念、发展历程、主要内容和实际应用进行详细介绍编译原理是计算机专业的一门核心课程,旨在介绍编译程序构造的一般原理和基本

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值