用char类型(8位)实现16位二进制数运算

这篇博客介绍了如何使用C++编写一个函数来判断无进位加法过程中的进位情况。代码中展示了如何处理两个无符号字符数组的加法,并通过逻辑位移判断是否发生进位。主要关注了低八位的最高位,根据二者的值来确定是否进位,确保在无进位的情况下正确执行加法运算。
摘要由CSDN通过智能技术生成

对于减法运算,由于无进位考虑,较为简单这里就不列举

下面是加法运算:

#include <iostream>
using namespace std;

unsigned char carry_judge(unsigned char *op1, unsigned char *op2, unsigned char r)
{
    unsigned char x1, x2,x3;
    x1 = op1[1];
    x2 = op2[1];
    x3 = r;
    x1 >>=7;
    x2 >>= 7;
    x3 >>= 7;
    if ((x1 == 1 && x2 == 1)|| (x1 == 1 && x2 == 0 && x3 == 0)|| (x2 == 1 && x1 == 0 && x3 == 0)) return 0b00000001;   
    else return 0b00000000;
}
int main()
{
    unsigned char op1[2] = { 0b01110110,0b10111100 };
    unsigned char op2[2] = { 0b01111110,0b11100011 };
    unsigned char result[2],c;
    result[1] = op1[1] + op2[1];
    c = carry_judge(op1, op2, result[1]);
    result[0] = op1[0] + op2[0] + c;
}

原理:关键在低八位是否进位,对于低八位的最高位,若二者均为1则必进位,若均为0则必不进位,关键讨论一个0一个1的情况,对二者低八位相加的结果进行判断,若相加结果的最高位为0,则发生进位,若为1,则未发生进位

注意,类型要定义为unsigned char,若为char类型,由于c不支持逻辑右移,而算术右移(>>)会导致在高位填1,发生错误。      

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值