leetcode -- 268

268.缺失数字

题目描述

给定一个包含 0, 1, 2, …, n 中 n 个数的序列,找出 0 … n 中没有出现在序列中的那个数。

示例 1:

输入: [3,0,1]
输出: 2

示例 2:

输入: [9,6,4,2,3,5,7,0,1]
输出: 8
说明:
你的算法应具有线性时间复杂度。你能否仅使用额外常数空间来实现?

解题方法

方法一:排序

方法二:等差数列前n项和

int missingNumber(int* nums, int numsSize)
{
    int sum = 0.5*(numsSize*(numsSize+1));
    int numsSum = 0;
    for (int i = 0; i < numsSize; i ++)
        numsSum += nums[i];
    return sum - numsSum;
}

在这里插入图片描述

发布了184 篇原创文章 · 获赞 253 · 访问量 34万+

猜你喜欢

转载自blog.csdn.net/williamgavin/article/details/104562645