Given a non-negative integer num represented as a string, remove k digits from the number so that the new number is the smallest possible.
Note: The length of num is less than 10002 and will be ≥ k. The given num does not contain any leading zero. Example 1:
Input: num = "1432219", k = 3 Output: "1219" Explanation: Remove the three digits 4, 3, and 2 to form the new number 1219 which is the smallest. Example 2:
Input: num = "10200", k = 1 Output: "200" Explanation: Remove the leading 1 and the number is 200. Note that the output must not contain leading zeroes. Example 3:
Input: num = "10", k = 2 Output: "0" Explanation: Remove all the digits from the number and it is left with nothing which is 0.
Given a binary array, find the maximum number of consecutive 1s in this array.
Example 1: Input: [1,1,0,1,1,1] Output: 3 Explanation: The first two digits or the last three digits are consecutive 1s. The maximum number of consecutive 1s is 3. Note:
The input array will only contain 0 and 1. The length of input array is a positive integer and will not exceed 10,000
解题方案
思路 1 **- 时间复杂度: O(N)**- 空间复杂度: O(N)**
使用temp保存每个0之间的差值
找出最大的差值即可
代码:
1 2 3 4 5 6 7 8 9 10 11 12 13
/** * @param {number[]}nums * @return {number} */ var findMaxConsecutiveOnes = function(nums) { var max = 0,temp = 0; for(var i =0;i<nums.length;i++){ nums[i]===0?temp=0:temp++; max = Math.max(temp,max); } return max; };