admin管理员组

文章数量:1794759

【变态面试题】【两种解法】不能创建临时变量(第三个变量),实现两个数的交换

题目:不能创建临时变量(第三个变量),实现两个数的交换。

错误解法:创建临时变量

       当我们没有注意到不能创建临时变量时,拿到这道题,就会觉得so easy~

直接哐哐敲代码

代码语言:javascript代码运行次数:0运行复制
#include<stdio.h>
int main()
{
	int a = 10;
	int b = 20;
	int c = a;//临时变量
	printf("交换前a:%d\n", a);
	printf("交换前b:%d\n", b);
	a = b;
	b = c;
	printf("交换后a:%d\n", a);
	printf("交换后b:%d\n", b);
}

 但是这样的错误的,因为创建了临时变量。而不创建临时变量,就必须思考如何使用已有的两个数来实现。而这两个数已经初始化了,所以这能动的就只有赋值了。在这里,我提供两种解法。

法一:利用两个数的和

代码语言:javascript代码运行次数:0运行复制
#include<stdio.h>
int main()
{
	int a = 10;
	int b = 20;
	printf("交换前a:%d\n", a);
	printf("交换前b:%d\n", b);
	a = a + b;//得到两个数的和
	b = a - b;//实现a的值交换给b
	a = a - b;//实现b的值交换给a
	printf("交换后a:%d\n", a);
	printf("交换后b:%d\n", b);
}

法二:利用^

a ^ a==0 a ^ 0==a

代码语言:javascript代码运行次数:0运行复制
#include<stdio.h>
int main()
{
	int a = 10;
	int b = 20;
	printf("交换前a:%d\n", a);
	printf("交换前b:%d\n", b);
	a = a ^ b;
	b = a ^ b;//相当于a ^ b ^ b == a ^ 0 == a
	a = a ^ b;//相当于a ^ b ^ a == 0 ^ b = b 
	printf("交换后a:%d\n", a);
	printf("交换后b:%d\n", b);
}

 运行结果: 

期待 

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。 原始发表:2024-02-18,如有侵权请联系 cloudcommunity@tencent 删除includeintstdio变量

本文标签: 变态面试题两种解法不能创建临时变量(第三个变量),实现两个数的交换