c语言中按位异或的作用,C语言 按位异或实现加法(示例代码)

c语言中按位异或的作用,C语言 按位异或实现加法(示例代码)/*C语言按位异或实现加法*/#include#include#includevoidtest1(){inta=2;intb=3;intcand=0;intcxor=0;intc=0;//实现c=a+b//1.不考虑进位,按位计算各位累加(用异或实现),得到值xor;cxor=a^b;/*实现说明:a的值是2,对应计算机中补码是0000000000000…

大家好,又见面了,我是你们的朋友全栈君。

/*C语言 按位异或实现加法*/#include#include#include

voidtest1()

{int a = 2;int b = 3;int cand = 0;int cxor = 0;int c = 0;//实现c=a+b//1.不考虑进位,按位计算各位累加(用异或实现),得到值xor;

cxor = a^b;/*实现说明:

a的值是2,对应计算机中补码是 0000 0000 0000 0000 0000 0000 0000 0010

b的值是3,对应计算机中补码是 0000 0000 0000 0000 0000 0000 0000 0011

a^b即

0000 0000 0000 0000 0000 0000 0000 0010

0000 0000 0000 0000 0000 0000 0000 0011

0000 0000 0000 0000 0000 0000 0000 0001 —>异或结果*/

//2.考虑进位,进行位与运算之后,结果左移1位

cand = a&b;/*实现说明:

a的值是2,对应计算机中补码是 0000 0000 0000 0000 0000 0000 0000 0010

b的值是3,对应计算机中补码是 0000 0000 0000 0000 0000 0000 0000 0011

a^b即

0000 0000 0000 0000 0000 0000 0000 0010

0000 0000 0000 0000 0000 0000 0000 0011

0000 0000 0000 0000 0000 0000 0000 0010 —>与结果

0000 0000 0000 0000 0000 0000 0000 0100 —>与结果左移1位,即cand的值*/

//3.进行求和计算

c = cxor + (cand << 1);/*实现说明:

0000 0000 0000 0000 0000 0000 0000 0001 —>异或结果

0000 0000 0000 0000 0000 0000 0000 0100 —>与结果左移1位,即cand的值

0000 0000 0000 0000 0000 0000 0000 0101 —>最终结果是5*/printf(“–test1–c[%d]–“, c);

}voidtest2()

{int a = -2;int b = 3;int cand = 0;int cxor = 0;int c = 0;//实现c=a+b//1.不考虑进位,按位计算各位累加(用异或实现),得到值xor;

cxor = a^b;/*实现说明:

a的值是2,对应计算机中补码是 1 111 1111 1111 1111 1111 1111 1111 1110

b的值是3,对应计算机中补码是 0 000 0000 0000 0000 0000 0000 0000 0011

a^b即

1 111 1111 1111 1111 1111 1111 1111 1110

0 000 0000 0000 0000 0000 0000 0000 0011

1 111 1111 1111 1111 1111 1111 1111 1101 —>异或结果*/

//1.考虑进位,进行位与运算之后,结果左移1位

cand = a&b;/*实现说明:

a的值是2,对应计算机中补码是 1 111 1111 1111 1111 1111 1111 1111 1110

b的值是3,对应计算机中补码是 0 000 0000 0000 0000 0000 0000 0000 0011

a^b即

1 111 1111 1111 1111 1111 1111 1111 1110

0 000 0000 0000 0000 0000 0000 0000 0011

0 000 0000 0000 0000 0000 0000 0000 0010 —>与结果

0 000 0000 0000 0000 0000 0000 0000 0100 —>与结果左移1位,即cand的值*/

//3.进行求和计算

c = cxor + (cand << 1);/*实现说明:

1 111 1111 1111 1111 1111 1111 1111 1101 —>异或结果

0 000 0000 0000 0000 0000 0000 0000 0100 —>cand的值

0 000 0000 0000 0000 0000 0000 0000 0001 —>最终结果是1*/printf(“–test2–c[%d]–“, c);

}intmain()

{

test1();

test2();

printf(“——–ok——-“);

getchar();return 0;

}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/142687.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • phantomjs 简介「建议收藏」

    phantomjs 简介「建议收藏」在爬虫、自然语言处理群320349384中的交流中,偶然接触到phantomjs、casper等相对于httpclient较新的框架及采集解决方案,微查之后发现方案可行,故尽清明三日之力,将其二次开发应用于百度元搜索信息采集项目中,达到预期效果,下一步将重点应用到腾讯微博采集和抢票抢手机项目中。下面,将分步骤介绍一下。  一、phantomjs介绍   (1)一个基于web

  • HDU 3715 Go Deeper(2-sat)

    HDU 3715 Go Deeper(2-sat)

  • 奔图m7160dw驱动_奔图打印机m7100dn

    奔图m7160dw驱动_奔图打印机m7100dn奔图M7100dW打印机驱动是专门为奔图旗下的M7100dW型号打印机打造的驱动程序。它能够为你解决打印机常见的无法扫描、无法识别等问题。他是连接打印机与电脑的桥梁,让你更好的操作这款的打印机。【打印机特色】1、操作便捷,乐在其中ECOSYSP2135dn外观小巧,空间适应度很高,可以更好地满足用户办公空间布置的需要。而且外形美观,放置在办公桌上能够与办公家具很好地融合在一起,营造出和谐的办公室…

  • c++算法之最长递增子序列(LIS)

    c++算法之最长递增子序列(LIS)题目:输入一个整数n,随后输入n个整数,求这个长度为n的序列中严格递增的子序列的最长长度。例:输入:6143265输出:3解题思路:动态规划。将输入的序列存入一个数组v中,另外再定义一个数组a,用以存储以当前数字v[i]结尾时,最长递增子序列的长度是多少。定义数组时,全部初始化为1,初始状态表示的是最坏的情况,以v[i]结尾的最长递增子序列就是v[i]它本身,长度为1。接着将v[i]逐一…

  • Instruments10 分析某个类中方法的执行时间

    Instruments10 分析某个类中方法的执行时间

  • 点击超链接不跳转的方式[通俗易懂]

    点击超链接不跳转的方式

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号