2021 8月10日

1.交换两个变量,要求不能使用第三方变量。

异或运算符

#include<stdio.h>
int main()
{
int a=3;
int b=5;
printf("交换前a=%d b=%d\n",a,b);
a=a^b;
b=a^b
a=a^b;
printf("交换后 a=%d b=%d",a,b);
return 0;
}

2.找出只出现一次的数,给定一个非空整型数组,除了某个元素只出现一次以外,其余每个元素均出现两次,找出那个只出现了一次的元素。

样例:a[]={1,2,3,4,5,1,2,3,4};该数组中只有5出现了一次,其他数字都是成对,要找出5.

第一种暴力求解:

#include<stdio.h>
int main(){
int arr[]={1,2,3,4,5,1,2,3,4,7,5,4};
//找出单身狗
int i=0;
int sz=sizeof(arr)/sizeof(arr[0]);
for(i=0;i<sz;i++)//第一次遍历
{
//统计arr[i]在数组中出现了几次
   int count =0;
   int j =0;
for(j=0;j<sz;j++)
{
if(arr[i] ==arr[j])
{    count++;
}}
if(count==1)
{
printf("单身狗:%d\n",arr[i]);
break;}}
return 0;}

第二种算法优化:异或满足交换律

#include<stdio.h>
int main(){
int arr[]={1,2,3,4,5,1,2,3,4};
int i=0;
int ret=0;
int sz=sizeof(arr)/sizeof(arr[0]);
for(i=0;i<sz;i++){
ret=ret^arr[i];
}
printf("%d\n",ret);
return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值