【Leetcode】【消失的数字】【C语言】

方法一:按位异或(找单身狗)

我们知道:按位异或^操作原则:相同为零,相异为一

所以 0^a=a a ^a=0 a ^b=b ^a

c 复制代码
int missingNumber(int* nums, int numsSize){
int i = 0;
int tem1 = 0,tem2=0;
for (i = 0;i < numsSize;i++)
{
	tem1 = tem1 ^ nums[i];
}
for (i = 1;i <= numsSize;i++)
{
	tem2 = tem2 ^ i;
}
int missnum = tem1 ^ tem2;
return missnum;
}

tem1 ^ tem2时,相同的元素互相按位异或都会变成0,而消失的数字就会显现出来。

方法二:求和相减

c 复制代码
int missingNumber(int* nums, int numsSize){
    int sum1=(1+numsSize)*numsSize/2;
    int sum2=0;
    for(int i=0;i<numsSize;i++)
    {
        sum2=sum2+nums[i];
    }
    return sum1-sum2;

等差数列求和公式求前n个数的和

相关推荐
玩具猴_wjh2 小时前
12.9 学习笔记
笔记·学习
Gomiko8 小时前
C/C++基础(五):分支
c语言·c++
wearegogog1238 小时前
光谱分析波段选择的连续投影算法
算法
执笔论英雄8 小时前
【RL】DAPO 数据处理
算法
不会代码的小猴9 小时前
C++的第九天笔记
开发语言·c++·笔记
why1519 小时前
面经整理——算法
java·数据结构·算法
Yeats_Liao9 小时前
CANN Samples(十三):Ascend C 算子开发入门
c语言·开发语言
专注于大数据技术栈9 小时前
java学习--枚举(Enum)
java·学习
悦悦子a啊9 小时前
将学生管理系统改造为C/S模式 - 开发过程报告
java·开发语言·算法
痕忆丶10 小时前
双线性插值缩放算法详解
算法