转自CSDN (原文地址 http://blog.csdn.net/zhongjiekangping/article/details/6855864)
用位运算实现加法也就是计算机用二进制进行运算,32位的CPU只能表示32位内的数,这里先用1位数的加法来进行,在不考虑进位的基础上,如下
- 1 + 1 = 0
- 1 + 0 = 1
- 0 + 1 = 1
- 0 + 0 = 0
很明显这几个表达式可以用位运算的“^”来代替,如下
- 1 ^ 1 = 0
- 1 ^ 0 = 1
- 0 ^ 1 = 1
- 0 ^ 0 = 0
这样我们就完成了简单的一位数加法,那么要进行二位的加法,这个方法可行不可行呢?肯定是不行的,矛盾就在于,如何去
获取进位?要获取进位我们可以如下思考:
- 0 + 0 = 0
- 1 + 0 = 0
- 0 + 1 = 0
- 1 + 1 = 1
- //换个角度看就是这样
- 0 & 0 = 不进位
- 1 & 0 = 不进位
- 0 & 1 = 不进位
- 1 & 1 = 进位
正好,在位运算中,我们用“<<”表示向左移动一位,也就是“进位”。那么我们就可以得到如下的表达式
- //进位可以用如下表示:
- (x&y)<<1
到这里,我们基本上拥有了这样两个表达式
- x^y //执行加法
- (x&y)<<1 //进位操作
我们来做个2位数的加法,在不考虑进位的情况下
- 11+01 = 100 // 本来的算法
- // 用推算的表达式计算
- 11 ^ 01 = 10
- (11 & 01) << 1 = 10
- //到这里 我们用普通的加法去运算这两个数的时候就可以得到 10 + 10 = 100
- //但是我们不需要加法,所以要想别的方法,如果让两个数再按刚才的算法计算一次呢
- 10 ^ 10 = 00
- (10 & 10) << 1 = 100
到这里基本上就得出结论了,其实后面的那个 “00” 已经不用再去计算了,因为第一个表达式就已经算出了结果。
继续推理可以得出三位数的加法只需重复的计算三次得到第一个表达式的值就是计算出来的结果。
c代码如下:
int Add(int a,int b)
{
int jw=a&b;
int jg=a^b;
while(jw)
{
int t_a=jg;
int t_b=jw<<1;
jw=t_a&t_b;
jg=t_a^t_b;
}
return jg;
}
计算机本质是二进制运算,许多高人和天书都展示了如何用位运算来实现让人纠结却又惊奇的事情。在豆瓣上看到一篇日志描述如何用位运算实现乘法,其实问题解决的关键是如何用位运算实现加法。觉得原文叙述不够精确,现总结如下。
定理1:设a,b为两个二进制数,则a+b = a^b + (a&b)<<1。
证明:a^b是不考虑进位时加法结果。当二进制位同时为1时,才有进位,因此 (a&b)<<1是进位产生的值,称为进位补偿。将两者相加便是完整加法结果。
定理2:使用定理1可以实现只用位运算进行加法运算。
证明:利用定理1中的等式不停对自身进行迭代。每迭代一次,进位补偿右边就多一位0,因此最多需要加数二进制位长度次迭代,进位补偿就变为0,这时运算结束。
相关推荐
本篇文章将深入探讨如何在易语言中通过位运算实现加法功能。 首先,让我们了解易语言的基本语法。易语言是一种中文编程语言,它的设计目标是使编程变得更加简单,易于理解和学习。在易语言中,我们使用关键字和函数...
本篇将深入探讨易语言中如何利用位运算实现加法运算。 一、位运算简介 位运算是对数据的二进制表示进行操作,包括按位与(&)、按位或(|)、按位异或(^)、按位非(~)、左移()和右移(>>)等操作。这些运算符在处理二进制...
这里有一个使用位运算实现加法的C语言函数示例: ```c int Add(int a, int b) { int jw = a & b; // 获取进位 int jg = a ^ b; // 执行不进位加法 while (jw) { // 当有进位时继续循环 int t_a = jg; int t_b ...
在“易语言源码易语言位运算实现加法运算源码.rar”这个压缩包中,包含的是一段用易语言编写的源代码,主要实现了利用位运算进行加法计算的功能。位运算在计算机科学中是基础且重要的概念,它涉及到二进制级别的数据...
神经网络实现加法运算神经网络实现加法运算神经网络实现加法运算神经网络实现加法运算神经网络实现加法运算神经网络实现加法运算神经网络实现加法运算神经网络实现加法运算神经网络实现加法运算神经网络实现加法运算...
实现加法运算实现加法运算实现加法运算实现加法运算
在这个“mfc 实现加法运算”的案例中,我们可能会创建一个对话框类,用于显示输入框和按钮,让用户输入两个数字并执行加法运算。 1. **创建MFC对话框项目** - 在Visual Studio中,选择“文件”->“新建”->“项目...
实现进行加法运算,输入的数字存到数组里面,然后进行加法运算
logisim实验MIPS运算器(ALU)设计(内含4位先行进位74182、四位快速加法器、32位快速加法器)-Educoder_logisim里面连线,实现4位先行进位74182和4位快速加法器-C
"8位串行加法器" ...本文介绍了使用一位二进制全加器设计的8位串行二进制全加器的知识点,包括加法器的基本概念、一位二进制全加器、8位串行二进制全加器的设计、VHDL 语言实现、半加器和或门电路的实现等内容。
例如,在进行幂模运算时,先用加法链优化常规的幂运算,然后使用蒙哥马利算法进行模运算。这种方式可以同时利用两者的优点,尤其是在处理大数和大模数时,计算速度会有显著提升。 在提供的压缩包文件"test7"中,...
利用java完成图形化用户界面实现加法运算,第一个加第二个当点击等号时在第三个文本框中显示相加之和
本项目涉及的是32位超前进位加法器的设计,使用Verilog硬件描述语言(HDL)进行实现。Verilog是一种广泛使用的用于描述数字系统硬件的编程语言,特别是在VLSI(超大规模集成电路)设计领域。 32位超前进位加法器是...
在Vivado中,我们可以使用Verilog或VHDL这两种HDL语言来实现4位先行进位加法器。设计通常包括4个半加器和3个全加器,每个全加器接收两个输入位和一个进位输入,输出一个和位和一个进位输出。4位先行进位加法器还需要...
总之,易语言位运算实现加法运算源码提供了一个实践位运算的好例子,适合想要提升编程技能,尤其是对位运算感兴趣的开发者。通过学习和研究这段源码,不仅能掌握位运算的原理,还能提升在低级别数据处理方面的编程...
在本文中,我们将讨论如何使用十字链表表示稀疏矩阵,并实现矩阵的加法运算。 一、十字链表的定义 十字链表是一种特殊的链表结构,每个结点都有两个指针,分别指向行和列的下一个结点。这种结构使得我们可以快速地...
3. **加法容错**:在实现加法容错功能时,我们可以通过检查OF标志来确保结果的有效性。如果发生溢出,我们可能需要执行一些错误处理代码,比如将结果设置为无效值或抛出异常。此外,还可以使用ADC(Add with Carry)...
最终,最高位的进位信号成为整个加法运算的结果的一部分。 在微处理器设计中,加法器通常是算术逻辑单元(ALU)的一部分,ALU负责执行基本的算术和逻辑运算。当CPU执行加法指令时,它会将操作数加载到寄存器中,...
32位进位选择加法器是一种用于数字逻辑设计中的电路结构,主要目的是高效地执行32位二进制数的加法运算。在计算机体系结构中,这种加法器是构建算术逻辑单元(ALU)的关键部分,用于执行基本的算术操作。以下是对该...