• 【LeetCode】刷题日记01


    1. 第三大的数

    找到一个数组第三大的数并返回这个数,如果没有就返回最大的数。

    /**
     * @param {number[]} nums
     * @return {number}
     */
    var thirdMax = function(nums) {
        for (i = 0; i < nums.length; i++){
            for (j = i+1; j < nums.length; j++){
                if (nums[i] == nums[j]){
                    nums.splice(j, 1);
                    --j;
                }
            }
        }
        //现在数组中没有重复元素了
        nums.sort((a, b) => b - a);
        return nums.length>2 ? nums[2] : nums[0];
    };

    Tips: 这道题包含一个去除数组中重复元素的方法。注意那个--j。

    2. 和为k的子数组

    /**
     * @param {number[]} nums
     * @param {number} k
     * @return {number}
     */
    var subarraySum = function(nums, k) {
        let count = 0;
        for (let start = 0; start < nums.length; ++start) {
            let sum = 0;
            for (let end = start; end >= 0; --end) {
                sum += nums[end];
                if (sum == k) {
                    count++;
                }
            }
        }
        return count;
    };

    Tips: 这道题的重点在于掌握双重循环,第二层可以从后往前计算和的方法。

    3. 数组嵌套

    如果一个数组S[i] = [ A[i], A[A[I]], A[A[A[I]]], ......],则称为一个嵌套数组。返回给定数组的最大嵌套数组长度。

    /**
     * @param {number[]} nums
     * @return {number}
     */
    var arrayNesting = function(nums) {
        let ans = 0;
        for(let i = 0; i < nums.length; i++) {
            let start = i;
            let count = 0;  //长度计数器
            while(nums[start] !== Infinity) {
                count++;
                let temp = start;
                start = nums[start];
                nums[temp] = Infinity;
            }
            if(count > ans) ans = count;
        }
        return ans;
    };

    Tips: 注意黄色高亮部分,这是打破while循环的方式。一开始只想到了置为一个特定值,没有想到可以利用Infinity这个特殊值。粉色部分是嵌套数组的方法。

  • 相关阅读:
    Redis Cluster笔记
    http协议之 COOKIE
    lor框架代码分析
    PHP--SPL扩展学习笔记
    lua协程----ngx-lua线程学习笔记
    设计模式
    eclipse中使用maven创建springMVC项目
    一般处理程序里使用session对象
    .Dot NET Cored简介
    Spring 依赖注入(基本注入和自动适配注入)
  • 原文地址:https://www.cnblogs.com/hermionepeng/p/13255611.html
Copyright © 2020-2023  润新知