给定一个包含 0, 1, 2, ..., n 中 n 个数的序列,找出 0 .. n 中没有出现在序列中的那个数。
示例 1:
输入: [3,0,1]
输出: 2
示例 2:
输入: [9,6,4,2,3,5,7,0,1]
输出: 8
说明:
你的算法应具有线性时间复杂度。你能否仅使用额外常数空间来实现?
class Solution:
def missingNumber(self, nums: [int]) -> int:
nums.sort()
for index, num in enumerate(nums):
if index != num:
return index
return len(nums)class Solution:
def missingNumber(self, nums: [int]) -> int:
sum_number = sum(nums)
length = len(nums)
sum_number1 = (length + 1) * length // 2
return sum_number1 - sum_numberclass Solution {
public:
int missingNumber(vector<int>& nums) {
sort(nums.begin(), nums.end());
for (auto i = 0; i < nums.size(); i++) {
if (nums[i] != i) {
return i;
}
}
return nums.size();
}
};class Solution {
public:
int missingNumber(vector<int>& nums) {
int number = nums.size();
for (int i = 0; i < nums.size(); i++) {
number ^= i ^ nums[i];
}
return number;
}
};按照数学公式(高斯求和公式),$\sum_{i=0}^{n}i=\frac{n(n+1)}{2}$ 计算出 n 的总长度,然后减去数组中各元素的值,即可得到缺失的值
根据异或的特性,结合率,0 与任何数异或都是任何数,两次与同一个数异或变回本身。可以计算出缺失值,与求和法类似。
给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。
示例:
输入:
[0,1,0,3,12]输出:
[1,3,12,0,0]
说明:
-
必须在原数组上操作,不能拷贝额外的数组。
-
尽量减少操作次数。
class Solution:
def moveZeroes(self, nums: [int]):
left = 0
right = 0
length = len(nums)
while right < length:
if nums[right] != 0:
nums[left] = nums[right]
left += 1
right += 1
nums[left:right] = [0 for _ in range(right - left)]class Solution {
public:
void moveZeroes(vector<int> &nums) {
int left = 0, right = 0, count = nums.size();
while (left < count) {
if (right < count) {
if (nums[right] != 0) {
nums[left++] = nums[right];
}
right += 1;
} else {
nums[left++] = 0;
}
}
}
};给定一个非空数组,返回此数组中第三大的数。如果不存在,则返回数组中最大的数。要求算法时间复杂度必须是O(n)。
示例 1:
输入: [3, 2, 1]
输出: 1
解释: 第三大的数是 1.
示例 2:
输入: [1, 2]
输出: 2
解释: 第三大的数不存在, 所以返回最大的数 2 .
示例 3:
输入: [2, 2, 3, 1]
输出: 1
解释: 注意,要求返回第三大的数,是指第三大且唯一出现的数。
存在两个值为2的数,它们都排第二。
class Solution:
def thirdMax(self, nums: [int]) -> int:
nums = list(set(nums))
nums.sort()
if len(nums) >= 3:
return nums[-3]
else:
return nums[-1]// 有三个指针分别表示第一大,第二大,第三大
class Solution {
public:
int thirdMax(vector<int> &nums) {
int *max_number = nullptr;
int *second_number = nullptr;
int *third_number = nullptr;
for (auto &num : nums) {
if (max_number == nullptr) {
max_number = #
} else if (num == *max_number) {
continue;
} else if (num > *max_number) {
third_number = second_number;
second_number = max_number;
max_number = #
} else if (second_number == nullptr) {
second_number = #
} else if (num == *second_number) {
continue;
} else if (num > *second_number) {
third_number = second_number;
second_number = #
} else if (third_number == nullptr) {
third_number = #
} else if (num > *third_number) {
third_number = #
}
}
return third_number != nullptr ? *third_number : *max_number;
}
};给定一个范围在 1 ≤ a[i] ≤ n ( n = 数组大小 ) 的 整型数组,数组中的元素一些出现了两次,另一些只出现一次。
找到所有在 [1, n] 范围之间没有出现在数组中的数字。
您能在不使用额外空间且时间复杂度为O(n)的情况下完成这个任务吗? 你可以假定返回的数组不算在额外空间内。
示例:
输入:
[4,3,2,7,8,2,3,1]
输出:
[5,6]
class Solution:
def findDisappearedNumbers(self, nums: [int]) -> [int]:
rel = []
count = len(nums)
for index, num in enumerate(nums):
nums[(num - 1) % count] += count
for index, num in enumerate(nums):
if num <= count:
rel.append(index+1)class Solution {
public:
vector<int> findDisappearedNumbers(vector<int> &nums) {
vector<int> v;
for (auto num : nums) {
nums[(num - 1) % nums.size()] += nums.size();
}
for (size_t i = 0; i < nums.size(); i++) {
if (nums[i] <= nums.size()) {
v.push_back(i + 1);
}
}
return v;
}
};该题采用两次遍历
- 第一次给所有数据应该出现在的位子做一个特定的标记
- 第二次遍历到查找没有标记的位子,该位置就是就是消失的数字
给定一个二进制数组, 计算其中最大连续1的个数。
示例 1:
输入: [1,1,0,1,1,1]
输出: 3
解释: 开头的两位和最后的三位都是连续1,所以最大连续1的个数是 3.
注意:
- 输入的数组只包含 0 和1。
- 输入数组的长度是正整数,且不超过 10,000。
class Solution:
def findMaxConsecutiveOnes(self, nums: [int]) -> int:
max_length = 0
current_length = 0
for num in nums:
if num == 0:
if max_length < current_length:
max_length = current_length
current_length = 0
else:
current_length += 1
if max_length < current_length:
max_length = current_length
return max_lengthclass Solution {
public:
int findMaxConsecutiveOnes(vector<int> &nums) {
int max = 0, current = 0;
for (int num : nums) {
if (num) {
current += 1;
} else {
if (current > max)
max = current;
current = 0;
}
}
return max > current ? max : current;
}
};