JS leetcode 最大连续1的个数 题解分析
2021-02-16 16:17
标签:字符串 就是 简单 image sort java -o 十分 一点 今天来做一道十分烦躁的题目,为什么烦躁,因为我字母写错了提交了三次错了三次!!!我的leetcode正确率大大下降!!那么这道题是leetcode的485. 最大连续1的个数,题目描述如下: 给定一个二进制数组, 计算其中最大连续1的个数。 示例 1: 解释: 开头的两位和最后的三位都是连续1,所以最大连续1的个数是 3. 输入的数组只包含 0 和1。 我们先简单分析题目,说说我的实现思路,最后再给出优质题解。 首先很重要的一点,数组只包含数字0或1,而且数组的长度是正整数,也就是大于0的整数,所以数组至少有一位,那么我们就得考虑只有0像 我首先想到的就是用正则,我们先将数组转成字符串,然后用正则 那我们只需要将匹配的结果按长度排个序,取最后一位就好了: 那我们就直接贴代码: 我的提交错误一次就是没考虑[0]的情况,由于match匹配失败返回null, 那么第二种做法其实与正则类似,还是将数组转成字符串,然后按0进行切割,同样排序后取最后一位,这里就直接上代码,思路与上方相同: 虽然达到了效果,很遗憾这两种实现的实现都较慢,像这样: 由于这道题属于双指针分类,我想着怎么用双指针来解决这个问题,苦思冥想确实没想到好的办法,然后在看了优质解答后,顿时发现与双指针完全没啥关系....思想受限。 直接贴代码: 我想大家看了代码思路就很清晰了,以 一开始count为0,遇到第一个1,自增count变成1,又连续遇到2个1,此时count变成了3。 接下来遇到了0,所以我们得重置count,重置前将count与maxCount较大的数赋予maxCount,所以此时maxCount为3。 接着遍历,又遇到1,count变成1。由于遍历完成,再次比较count与maxCount,1与3之间3更大,所以最终返回了3。 思路很简单,但是我确实没想上去,那么关于此题分析就到这里了。 JS leetcode 最大连续1的个数 题解分析 标签:字符串 就是 简单 image sort java -o 十分 一点 原文地址:https://www.cnblogs.com/echolun/p/12969678.html壹 ? 引
输入: [1,1,0,1,1,1]
输出: 3
注意:
输入数组的长度是正整数,且不超过 10,000。贰 ? 解题思路
[0]
,或者[0,0,0,0,0,0,0]
以及只有1的情况[1,1,1,1,1,1]
。/1+/g
来匹配,+表示至少出现一次,比如:‘111011‘.match(/1+/g);// ["111", "11"]
["111", "11"].sort((a,b) => {
return a.length - b.length;
});
/**
* @param {number[]} nums
* @return {number}
*/
var findMaxConsecutiveOnes = function (nums) {
// 假设数组全部是1,那么直接返回数组length即可
if (nums.indexOf(0)
null.sort
直接报错了...阿西吧。/**
* @param {number[]} nums
* @return {number}
*/
var findMaxConsecutiveOnes = function (nums) {
if (nums.indexOf(0)
叁 ? 更优做法
/**
* @param {number[]} nums
* @return {number}
*/
var findMaxConsecutiveOnes = function (nums) {
// 计数器,每次遇到1让其自增
let count = 0;
// 当遇到0,就比较count与maxCount,将较大的值赋予maxCount
let maxCount = 0;
for (let i = 0; i
[1,1,1,0,1]
为例: