小小程序媛  
得之坦然,失之淡然,顺其自然,争其必然

题目

Given an array containing n distinct numbers taken from 0, 1, 2, …, n, find the one that is missing from the array.

For example,
Given nums = [0, 1, 3] return 2.

Note:
Your algorithm should run in linear runtime complexity. Could you implement it using only constant extra space complexity?

分析

给定包含n个元素的序列其元素为n+1元素序列{012...n}中的n个,找出缺失元素。

方法一:排序法 时间O(nlogn) 空间O(1)
现将序列元素排序,然后一次遍历i0n1,若nums[i]!=i,则i便是缺失元素,若循环正常结束,则缺失元素为n

方法二:
时间O(n) 空间O(1)
由题意,大小为n的数组里的所有数都是0n之间的数,作为等差数列,如果没有缺失的时候它的和是能O(1)计算出来的,所以我们遍历一遍记录最大、最小和数组和,用期望数组和减去实际数组和,就是缺失的整数。

AC代码

class Solution {
public:
    int missingNumber(vector<int>& nums) {
        if (nums.empty())
            return 0;

        sort(nums.begin(), nums.end());

        for (unsigned i = 0; i < nums.size(); ++i)
        {
            if (nums[i] != i)
                return i;
        }//for
        return nums.size();
    }
};

GitHub测试程序源码

posted on 2015-11-30 13:46  Coding菌  阅读(121)  评论(0编辑  收藏  举报