数据结构与算法——1127—异或^&&

1、不使用+-*/,实现加法

题目

5和7相加

解答

|-----------|---|---|---|---|
| 5的二进制 | 0 | 1 | 0 | 1 |
| 7的二进制 | 0 | 1 | 1 | 1 |
| 5和7异或 | 0 | 0 | 1 | 0 |
| 5和7位与 | 0 | 1 | 0 | 1 |
| 位与结果向左进1位 | 1 | 0 | 1 | 0 |

异或的结果和向左进位后的结果继续进行异或和位与左移的操作

操作步骤:

1、异或

2、位与操作

此时进行检测,如果位与的操作是0,异或的结果就是最后的结果

如果位与的操作不是0,继续操作

3、左移1位

4、更新计算对象

代码

复制代码
#include<iostream>
using namespace std;

int sum(int num1,int num2)
{
	int res1 ;
	int res2 ;
	while (1)
	{
		res1 = num1 ^ num2;
		res2 = num1 & num2;
		if (res2==0)
		{
			break;
		}
		res2 <<= 1;
		num1 = res1;
		num2 = res2;
	}
	return res1;
}

int main()
{
	int a = 5;
	int b = 7;

	cout << sum(a, b);
}

2、异或运算的使用场景

1、一般使用在==判断两个数字是否相等的情况下,将两个数字异或,判断是否为0

2、清零时使用,自己异或自己

3、两个数字相互交换

假设a=5,b=9,交换a、b的值。

a=a^b; //a=a与b亦或的值

b=a^b; //b=a与b亦或的值再亦或b,则两个b抵消,只剩a的值,则b就附上了a的值

a=a^b; //a=a与b亦或的值再亦或a,则两个a抵消,只剩b的值,则a就附上了b的值

相关推荐
佳哥的技术分享2 分钟前
kotlin基于MVVM架构构建项目
android·开发语言·kotlin
给大佬递杯卡布奇诺3 分钟前
FFmpeg 基本数据结构 URLContext分析
数据结构·c++·ffmpeg·音视频
hadage2333 分钟前
--- 单源BFS权值为一算法 迷宫中离入口最近的出口 ---
算法·宽度优先
zero13_小葵司6 分钟前
JavaScript 性能优化系列(六)接口调用优化 - 6.4 错误重试策略:智能重试机制,提高请求成功率
开发语言·javascript·ecmascript
无敌最俊朗@7 分钟前
SQLite 约束:INTEGER PRIMARY KEY 与 ROWID
java·开发语言
DARLING Zero two♡9 分钟前
Profile-Guided Optimization(PGO):Rust 性能优化的终极武器
开发语言·性能优化·rust
橘子师兄14 分钟前
c++中list详解
开发语言·c++
LDG_AGI14 分钟前
【推荐系统】深度学习训练框架(一):深入剖析Spark集群计算中Master与Pytorch分布式计算Master的区别
人工智能·深度学习·算法·机器学习·spark
LDG_AGI15 分钟前
【推荐系统】深度学习训练框架(二):深入剖析Spark Cluster模式下DDP网络配置解析
大数据·网络·人工智能·深度学习·算法·机器学习·spark
ai智能获客_狐狐18 分钟前
电商零售行业外呼优势
人工智能·算法·自然语言处理·语音识别·零售