力扣单调栈专题 739. 每日温度 496.下一个更大元素I 503.下一个更大元素II 42. 接雨水 84.柱状图中最大的矩形 步骤及C++实现 总结

news2024/12/24 8:24:58

文章目录

  • 739. 每日温度
  • 496.下一个更大元素 I
  • 503.下一个更大元素II
    • 方法一 数组拼接
    • 方法二 模拟遍历两边nums
  • 42. 接雨水
    • 双指针 暴力法
    • 双指针优化
    • 单调栈
  • 84.柱状图中最大的矩形
    • 暴力解法
    • 双指针解法
    • 单调栈
  • 总结

739. 每日温度

在这里插入图片描述

  1. 暴力解法,双层for循环,时间复杂度是O(n^2)。

  2. 什么时候用单调栈?
    通常是一维数组,要找任一个元素的右边(左边)第一个比自己大(小)的元素的位置,此时优先考虑单调栈,时间复杂度为O(n)。

  3. 使用单调栈时,首先要明确如下几点:

 1)单调栈里存放的元素是什么
   单调栈只需要存放元素的下标i,T[i]直接获取对应的元素。

 2)单调栈里元素是递增还是递减
   本题使用递增顺序(从栈头到栈底的顺序)。当单调栈递增,元素i入栈时,才能保证 元素i栈顶元素 在数组中右边第一个比自己大的元素,也就是说找到栈顶元素 右边第一个比自己大的元素是 元素i。

 3)三种情况:
  当前遍历的元素T[i]小于栈顶元素T[st.top()]的情况
  当前遍历的元素T[i]等于栈顶元素T[st.top()]的情况
  当前遍历的元素T[i]大于栈顶元素T[st.top()]的情况

  1. C++实现
class Solution {
public:
    vector<int> dailyTemperatures(vector<int>& temperatures) {
        //递增栈
        stack<int> st;//存放对应元素的下标
        vector<int> result(temperatures.size(), 0);
        st.push(0);//初始化
        for(int i=1; i<temperatures.size(); i++)
        {
            if(temperatures[i] < temperatures[st.top()]) st.push(i);//情况1  当前元素比栈顶元素小 当前元素入栈 
            else if(temperatures[i] == temperatures[st.top()]) st.push(i);//情况2  当前元素等于栈顶元素 当前元素入栈 
            else//情况3 当前元素比栈顶元素大 保存结果 栈顶出栈 当前元素入栈 
            {
                while(!st.empty() && temperatures[i] > temperatures[st.top()])
                {
                    result[st.top()] = i - st.top();
                    st.pop();
                }
                st.push(i);
            }
        }
        return result;
    }
};

简化

class Solution {
public:
    vector<int> dailyTemperatures(vector<int>& temperatures) {
        //递增栈 简化
        stack<int> st;
        vector<int> result(temperatures.size(), 0);
        st.push(0);
        for(int i=1; i<temperatures.size(); i++)
        {
            while(!st.empty() && temperatures[i] > temperatures[st.top()])
            {
                result[st.top()] = i - st.top();
                st.pop();
            }
            st.push(i);
        }
        return result;
    }
};

496.下一个更大元素 I

在这里插入图片描述
需要注意点:

  1. result数组初始化应该为多少?
     题目提示,如果不存在下一个更大元素就输出 -1,所以result数组初始化为-1。

  2. 遍历nums2时需要判断nums2[i]在nums1中是否出现过,因为最后是根据nums1元素的下标来更新result数组。

  3. 题目提示nums1 和 nums2是不重复的数组,因此可以用map做映射,根据数值快速找到下标,还可以判断nums2[i]是否在nums1中出现过。使用集合来解决哈希问题时,优先使用unordered_set,它的查询和增删效率是最优的。

  4. 单调递增栈顺序,栈头到栈底元素顺序要从小到大。栈内元素递增才能找到右边第一个比自己大的元素。

  5. 三种情况:

  • 当前遍历的元素T[i]小于栈顶元素T[st.top()],满足递增栈,直接入栈。
  • 当前遍历的元素T[i]等于栈顶元素T[st.top()]的情况,直接入栈,求的是右边第一个比自己大的元素,而不是大于等于
  • 当前遍历的元素T[i]大于栈顶元素T[st.top()]的情况,不满足递增栈,找到右边第一个比自己大的元素,对元素进行处理:栈里的元素是nums2的元素,判断栈顶元素是否在nums1里出现过。如果出现过就记录,此时栈顶元素在nums2数组中右面第一个大的元素是当前遍历元素nums2[i]。

C++实现

class Solution {
public:
    vector<int> nextGreaterElement(vector<int>& nums1, vector<int>& nums2) {
        stack<int> st;
        vector<int> result(nums1.size(), -1);//处理的是nums1的元素
        if(nums1.size() == 0) return result;
        //没有重复元素 map做映射 根据数值快速找到下标,判断nums2[i]是否在nums1中出现过。
        unordered_map<int, int> umap;// key:下标元素,value:下标  为了快速查找元素
        for(int i=0; i<nums1.size(); i++) umap[nums1[i]] = i;
        st.push(0);
        for(int i=1; i<nums2.size(); i++)
        {
            if(nums2[i] < nums2[st.top()]) st.push(i);
            else if(nums2[i] == nums2[st.top()]) st.push(i);
            else{
                while(!st.empty() && nums2[i] > nums2[st.top()])
                {
                    if(umap.count(nums2[st.top()]) > 0)//判断nums2[i]是否在nums1中出现过
                    {
                        int index = umap[nums2[st.top()]];
                        result[index] = nums2[i];//nums2[i]在nums1出现过,记录结果
                    }
                    st.pop();
                }
                st.push(i);
            }
        }
        return result;
    }
};

简化

class Solution {
public:
    vector<int> nextGreaterElement(vector<int>& nums1, vector<int>& nums2) {
        //三种情况合并写
        stack<int> st;
        vector<int> result(nums1.size(), -1);
        if(nums1.size() == 0) return result;
        st.push(0);

        //映射容器
        unordered_map<int, int> umap;
        for(int i=0; i<nums1.size(); i++) umap[nums1[i]] = i;

        //遍历nums2
        for(int i=1; i<nums2.size(); i++)
        {
            while(!st.empty() && nums2[i] > nums2[st.top()])
            {
                if(umap.count(nums2[st.top()]) > 0)
                {
                    int index = umap[nums2[st.top()]];
                    result[index] = nums2[i];
                }
                st.pop();
            }
            st.push(i);
        }
        return result;
    }
};

503.下一个更大元素II

在这里插入图片描述
在题496变形,一个循环数组找下一个更大的元素

方法一 数组拼接

把nums数组首尾拼接组成新的nums来操作,最后resize再返回结果。

class Solution {
public:
    vector<int> nextGreaterElements(vector<int>& nums) {
        //拼接数组
        vector<int> nums1(nums.begin(), nums.end());
        nums.insert(nums.end(), nums1.begin(), nums1.end());

        vector<int> result(nums.size(), -1);
        if(nums.size() == 0) return result;

        stack<int> st;
        st.push(0);
        for(int i=1; i<nums.size(); i++)
        {
            if(nums[i] < nums[st.top()]) st.push(i);
            else if(nums[i] == nums[st.top()]) st.push(i);
            else
            {
                while(!st.empty() && nums[i] > nums[st.top()])
                {
                    result[st.top()] = nums[i];
                    st.pop();
                }
                st.push(i);
            }
        }
        result.resize(nums.size() / 2);
        return result;
    }
};

方法二 模拟遍历两边nums

在遍历的过程中模拟走了两边nums,用i % nums.size()来代替i 操作

class Solution {
public:
    vector<int> nextGreaterElements(vector<int>& nums) {
        //遍历中模拟走了两边nums 用i % nums.size()来操作
        vector<int> result(nums.size(), -1);
        if(nums.size() == 0) return result;
        stack<int> st;
        st.push(0);

        for(int i=1; i<nums.size() * 2; i++)
        {
            if(nums[i % nums.size()] < nums[st.top()]) st.push(i % nums.size());
            else if(nums[i % nums.size()] == nums[st.top()]) st.push(i % nums.size());
            else 
            {
                while(!st.empty() && nums[i % nums.size()] > nums[st.top()])
                {
                    result[st.top()] = nums[i % nums.size()];
                    st.pop();
                }
                st.push(i % nums.size());
            }
        }
        return result;
    }
};

简化

class Solution {
public:
    vector<int> nextGreaterElements(vector<int>& nums) {
        //简化 遍历中模拟走了两边nums 用i % nums.size()来操作
        vector<int> result(nums.size(), -1);
        if(nums.size() == 0) return result;
        stack<int> st;
        st.push(0);

        for(int i=1; i<nums.size() * 2; i++)
        {
            while(!st.empty() && nums[i % nums.size()] > nums[st.top()])
            {
                result[st.top()] = nums[i % nums.size()];
                st.pop();
            }
            st.push(i % nums.size());
        }
        return result;
    }
};

42. 接雨水

在这里插入图片描述

双指针 暴力法

按照列来计算,宽度w=1,每一列雨水的高度取决于该列左侧最高的柱子右侧最高的柱子 ,两者中较矮的柱子高度

  • 列4的雨水高度 = min(列3高度, 列7高度) — 列4高度,height = min(lefth, righth) - h,列4雨水体积 = w * height。
    • 列4 左侧最高的柱子是列3,高度为2,lefth;
    • 列4 右侧最高的柱子是列7,高度为3,righth;
    • 列4 柱子的高度h为1;
  • 从头遍历所有列,求出每一列的雨水体积,再累加就是总雨水体积。注意第一个柱子和最后一个柱子不接雨水。
  • 双指针-超时 时间复杂度是 O ( n 2 ) O(n^2) O(n2)
class Solution {
public:
    int trap(vector<int>& height) {
        //双指针法 暴力解法 超时
        int sum = 0;
        for(int i=0 ;i<height.size(); i++)
        {
            //第一个和最后一个柱子不接水
            if(i == 0 || i == height.size()-1) continue;

            //更新当前柱子 左右两边柱子的最高高度
            int leftheight = height[i];// 记录左边柱子的最高高度
            int rightheight = height[i];// 记录右边柱子的最高高度
            for(int l=i-1; l>=0; l--)
            {
                if(height[l] > leftheight) leftheight = height[l];
            }
            for(int r=i+1; r<height.size(); r++)
            {
                if(height[r] > rightheight) rightheight = height[r];
            }

            //统计高度差 累加
            int h = min(rightheight, leftheight) - height[i];
            if(h > 0) sum += h;
        }
        return sum;
    }
};

双指针优化

暴力解法中,通过列来计算每一列的雨水体积再累加求出雨水总体积,其中,当前列雨水面积 = 1 * (min(左边柱子的最高高度,记录右边柱子的最高高度) - 当前柱子高度)。双指针遍历时,每到一个柱子都向两边遍历一遍,有重复计算。

优化:把每一个位置的左边最高高度记录在一个数组上maxLeft,右边最高高度记录在一个数组上maxRight,避免了重复计算:

  • 从左向右遍历:maxLeft[i] = max(height[i], maxLeft[i - 1]);
  • 从右向左遍历:maxRight[i] = max(height[i], maxRight[i + 1]);
  • 时间复杂度是 O ( n ) O(n) O(n)
class Solution {
public:
    int trap(vector<int>& height) {
        //双指针法 
        if(height.size() <= 2) return 0;

        //统计当前柱子左右两侧柱子最高高度
        vector<int> maxleft(height.size(), 0);
        vector<int> maxright(height.size(), 0);
        int size = maxright.size();
        //左边柱子 正序 当前柱子高度 容器上一个柱子高度
        maxleft[0] = height[0];//for循环从1开始遍历
        for(int i=1; i<size; i++) maxleft[i] = max(height[i], maxleft[i-1]);
        //右边柱子 倒叙 当前柱子高度 容器上一个柱子高度
        maxright[size-1] = height[size-1];
        for(int i=size-2; i>=0; i--) maxright[i] = max(height[i], maxright[i+1]);

        //累计高度 左右柱子中较矮的柱子高度-当前柱子高度=雨水长度
        //求的是面积 宽度=1 相当于统计长度
        int sum = 0;
        int h = 0;
        for(int i=0; i<size; i++)
        {
            h = min(maxright[i], maxleft[i]) - height[i];
            if(h>=0) sum += h;
        }
        return sum;
    }
};

单调栈

在这里插入图片描述

  • 需要找一个元素,及其右边最大元素和左边最大元素来计算雨水面积
  • 按照行方向来计算雨水,当前柱子左右两边柱子的高度差就是雨水面积的长度,下标差就是宽度
  • 单调栈内元素的顺序是从小到大,如果当前柱子高度大于栈头元素高度,出现凹槽,栈头元素就是凹槽底部的柱子,栈头第二个元素就是凹槽左边的柱子,添加元素就是凹槽右边的柱子。
  • 栈里要保存什么数值:使用单调栈,也是通过 长 * 宽 来计算雨水面积的。长就是通过柱子的高度来计算,宽是通过柱子之间的下标来计算
  • 单调栈处理逻辑,主要有三种情况
    • 情况一:当前遍历的元素(柱子)高度小于栈顶元素的高度 height[i] < height[st.top()]
    • 情况二:当前遍历的元素(柱子)高度等于栈顶元素的高度 height[i] == height[st.top()]
    • 情况三:当前遍历的元素(柱子)高度大于栈顶元素的高度 height[i] > height[st.top()]
  • 注意点:
    • 遇到相同高度的柱子,即相同的元素时,更新栈内下标,弹出栈内元素(旧下标),栈内加入新元素(新下标),如5、5、1、3,如果添加第二个5时,先将第一个5的下标弹出,再把第二个5入栈
    • 栈内存放元素下标,通过height[stack.top()]直接获取对应下标的高度
    • 栈中存放遍历过的元素,因此先将下标0入栈,st.push(0);
class Solution {
public:
    int trap(vector<int>& height) {
        //单调栈
        if(height.size() <= 2) return 0;

        stack<int> st;//柱子下标-雨水长度
        st.push(0);
        int sum = 0;
        int mid = 0;//凹槽最低
        int h = 0, w = 0;
        for(int i=1; i<height.size(); i++)
        {
            if(height[i] < height[st.top()]) st.push(i);//情况一
            else if(height[i] == height[st.top()])//情况二 保存较近的柱子高度
            {
                st.pop();
                st.push(i);
            }
            else//情况三 出现凹槽
            {
                while(!st.empty() && height[i] > height[st.top()])
                {
                    mid = st.top();//注意这是柱子下标
                    st.pop();//弹出凹槽底部
                    if(!st.empty())//如果还有元素 该栈顶元素才是凹槽左边高度
                    {
                        h = min(height[st.top()], height[i]) - height[mid];
                        w = i - st.top() - 1; // 注意减一,只求中间宽度
                        sum += h * w;
                    }
                }
                st.push(i);
            }
        }
        return sum;
    }
};

简化

class Solution {
public:
    int trap(vector<int>& height) {
        //单调栈 简化
        if(height.size() <= 2) return 0;
        stack<int> st;
        st.push(0);
        int sum = 0;
        int mid = 0, h = 0, w = 0;
        for(int i=1; i<height.size(); i++)
        {
            while(!st.empty() && height[i] > height[st.top()])
            {
                mid = st.top();//凹槽底部
                st.pop();
                if(!st.empty())
                {
                    h = min(height[i], height[st.top()]) - height[mid];
                    w = i - st.top() - 1;//减1才是凹槽底部的宽度
                    sum += h * w;
                }
            }
            st.push(i);
        }
        return sum;

    }
};

84.柱状图中最大的矩形

在这里插入图片描述

暴力解法

时间复杂度是 O ( n 2 ) O(n^2) O(n2)

class Solution {
public:
    int largestRectangleArea(vector<int>& heights) {
        //暴力解法 双指针 找左右最高柱子
        int sum = 0;
        for(int i=0; i<heights.size(); i++)
        {
            int left = i;
            int right = i;
            for(; left>=0; left--)
            {
                if(heights[left] < heights[i]) break;
            }
            for(; right<heights.size(); right++)
            {
                if(heights[right] < heights[i]) break;
            }
            int w = right - left - 1;
            int h = heights[i];
            sum = max(sum, h*w);
        }
        return sum;
    }
};

双指针解法

重点在于要记录每个柱子的左边第一个小于该柱子的下标,而不是高度。所以需要循环查找,使用while

class Solution {
public:
    int largestRectangleArea(vector<int>& heights) {
        //双指针 优化
        //记录的是左右两边最矮柱子中离得最近的柱子的下标
        int size = heights.size();
        vector<int> minleftindex(size);
        vector<int> minrightindex(size);

        // 记录每个柱子 左边第一个小于该柱子的下标
        minleftindex[0] = -1;//初始化,防止下面while死循环
        for(int i=1; i<size; i++)
        {
            int t = i-1;
            //找到离得最近的左边最矮柱子 不用if,而是不断向左寻找的过程
            while(t>=0 && heights[t] >= heights[i]) t = minleftindex[t];//记录该柱子的下标
            minleftindex[i] = t;//容器中更新下标
        }

        // 记录每个柱子 右边第一个小于该柱子的下标
        minrightindex[size-1] = size;
        for(int i=size-2; i>=0; i--)
        {
            int t = i+1;
            //不用if,而是不断向左寻找的过程
            while(t<size && heights[t] >= heights[i]) t = minrightindex[t];
            minrightindex[i] = t;
        }

        int sum = 0;
        int result = 0;
        for(int i=0; i<size; i++)
        {
            sum = heights[i] * (minrightindex[i] - minleftindex[i] - 1);
            result = max(sum, result);
        }
        return result;
    }
};

单调栈

  • 题42是找每个柱子左右两边第一个大于该柱子高度的柱子,而本题是找每个柱子左右两边第一个小于该柱子高度的柱子,因此单调栈的元素顺序是从大到小,这样才能保证栈顶元素找到左右两边第一个小于栈顶元素的柱子。
  • 要求的最大面积是由当前元素(要入栈元素)、栈顶元素、栈顶下一个元素组成凸性面积:
    • 当前元素是height[i] = 40,凸形的右边(相对于柱子60下标)
    • 栈顶元素是height[st.top()] = 60,凸形的顶部,中间位置
    • 栈顶下一个元素是50,凸形的左边(相对于柱子60下标)
  • 单调栈处理逻辑,主要有三种情况
    • 情况一:当前遍历的元素heights[i]大于栈顶元素heights[st.top()]的情况
    • 情况二:当前遍历的元素heights[i]等于栈顶元素heights[st.top()]的情况
    • 情况三:当前遍历的元素heights[i]小于栈顶元素heights[st.top()]的情况
class Solution {
public:
    int largestRectangleArea(vector<int>& heights) {
        //单调栈
        int result = 0;
        stack<int> st;
        //原数组头尾加入数字0分别为了避免数组是降序 升序时无法去三个值组成面积
        heights.insert(heights.begin(), 0);
        heights.push_back(0);
        st.push(0);
        //从大到小入栈 才能找到凸形面积
        for(int i=1; i<heights.size(); i++)//数组第一个元素已经入栈
        {
            if(heights[i] > heights[st.top()]) st.push(i);
            else if(heights[i] == heights[st.top()]) st.push(i);
            else
            {
                while(!st.empty() && heights[i] < heights[st.top()])
                {
                    int mid = st.top();
                    st.pop();
                    if(!st.empty())
                    {
                        int left = st.top();
                        int right = i;
                        int w = right - left - 1;//只要最高柱子的宽度
                        result = max(result, w * heights[mid]);
                    }
                }
                st.push(i);
            }
        }
        return result;
    }
};

化简

class Solution {
public:
    int largestRectangleArea(vector<int>& heights) {
        //单调栈 简化
        int result = 0;
        stack<int> st;
        heights.insert(heights.begin(), 0);
        heights.push_back(0);
        st.push(0);
        for(int i=1; i<heights.size(); i++)
        {
            while(!st.empty() && heights[i] < heights[st.top()])
            {
                int mid = st.top(); 
                st.pop();
                if(!st.empty())
                {
                    //int left = st.top();
                    //int right = i;
                    //right - left - 1
                    int w = i - st.top() - 1;
                    result = max(result, heights[mid] * w);
                }
            }
            st.push(i);
        }
        return result;
    }
};

总结

  1. 什么时候用单调栈?
  • 通常是一维数组,要找任一个元素的右边(左边)第一个比自己大(小)的元素的位置,此时优先考虑单调栈,时间复杂度为O(n)
  • 找右边第一个比自己大的元素位置,单调递增栈——题739、题496、题503
  • 找左边和右边第一个比自己大的元素位置,单调递增栈——题42
  • 找左边和右边第一个比自己小的元素位置,单调递递减——题84
  1. 单调栈的原理是什么?为什么时间复杂度是O(n)
  • 单调栈的本质是空间换时间,因为在遍历过程中需要用一个栈来记录右边第一个比当前元素大的元素。
  • 优点是整个数组只需要遍历一次,因此时间复杂度是O(n)。
  • 单调栈是用来记录遍历过的元素。遍历数组时,如果不知道哪些元素是遍历过的,会导致无法得知是否有一个比当前元素更小的元素被遍历了。所以要用一个容器——单调栈,来记录遍历过的元素。
  1. 使用单调栈时,首先要明确如下几点:

 1)单调栈里存放的元素是什么
   单调栈只需要存放元素的下标i,T[i]直接获取对应的元素。

 2)单调栈里元素是递增还是递减
   如果求一个元素右边第一个更大元素,单调栈是递增的,如果求一个元素右边第一个更小元素,单调栈是递减的。
   当单调栈递增,元素i入栈时,才能保证 元素i栈顶元素 在数组中右边第一个比自己大的元素,也就是说找到栈顶元素 右边第一个比自己大的元素是 元素i。

 3)三种情况:
  当前遍历的元素T[i]小于栈顶元素T[st.top()]的情况
  当前遍历的元素T[i]等于栈顶元素T[st.top()]的情况
  当前遍历的元素T[i]大于栈顶元素T[st.top()]的情况

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/702195.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

「完美解决」concrt140.dll丢失怎么恢复(解决方案)

我们平时在打开 Adobe 应用程序、Halo、Forza Horizon 5 等时&#xff0c;可能会遇到找不到 concrt140.dll。因此&#xff0c;这不是特定于某个应用程序的问题。如果没有安装正确的 DLL&#xff0c;应用程序将无法正常工作&#xff0c;因为它们的代码依赖于这些库中编写的代码。…

C++入门笔记--【精简完备】【快速入手】

目录 ​​​​​​​1 C初识 1.1 第一个C程序 1.1.1 创建项目 1.1.2 创建文件 1.1.3 编写代码 1.1.4 运行程序 1.2 注释 1.3 变量 1.4 常量 1.5 关键字 1.6 标识符命名规则 2 数据类型 2.1 整型 2.2 sizeof关键字 2.3 实型&#xff08;浮点型&#xff09; 2.4 字…

基于STM32单片机的大棚温度测控系统

目录 基于STM32单片机的大棚温度测控系统一、原理图二、部分代码三、视频演示 基于STM32单片机的大棚温度测控系统 功能&#xff1a; 1.通过LCD屏幕显示温湿度值和上限阈值 2.通过按键完成阈值加减功能 3.通过DHT11完成温湿度采集 4.若实时数据不满足条件&#xff0c;则进行降…

linux curl命令使用教程(curl指令)

文章目录 curl指令介绍curl的历史curl指令的安装Ubuntu/DebianCentOS/RHELFedoramacOSWindows curl使用方法示例使用curl命令注意事项 curl指令介绍 curl是一个用于发送HTTP请求的命令行工具&#xff0c;它支持多种协议&#xff0c;包括HTTP、HTTPS、FTP、SMTP等。curl可以用来…

人工智能:揭示未来科技所带来的革命性变革

目录 引言&#xff1a; 一、人工智能的定义与发展历程&#xff1a; 二、人工智能的应用领域&#xff1a; 三、人工智能对未来的影响&#xff1a; 结论&#xff1a; 引言&#xff1a; 在当今科技快速发展的时代&#xff0c;人工智能&#xff08;Artificial Intelligence&am…

开展全媒体营销的具体步骤和策略

随着移动互联网的发展和智能手机的普及&#xff0c;网络营销的主战场从PC端向移动端转移&#xff0c;新型的全媒体营销就是在如此的背景下兴起且被广泛应用。全媒体营销强调的是通过多个平台和渠道传播信息&#xff0c;与目标受众进行全方位、多角度的沟通。 企业如何高效开展全…

1σ Random Jitter of SSB for TIE Period

1σ Random Jitter of SSB for TIE & Period &#xff0c;该章节厘清了jitter基本概念&#xff0c;并给出了对应的表达式。

FineReport学习4

通过按钮控件来实现插入删除行 通过sql公式实现填报联动 设置插入行策略 通过sql实现控件联动

数据结构---------(2)排序

排序 1.选择排序 从待排序的数据中选择最小的元素&#xff0c;将其放在已排序的序列末尾&#xff0c;然后在剩余的数据中再选择最小的元素&#xff0c;放在已排序序列的末尾&#xff0c;以此类推&#xff0c;直到所有的数据都排好序为止。 public static void main(String[…

大数据分析案例-基于KMeans聚类算法对客户进行分群分析

&#x1f935;‍♂️ 个人主页&#xff1a;艾派森的个人主页 ✍&#x1f3fb;作者简介&#xff1a;Python学习者 &#x1f40b; 希望大家多多支持&#xff0c;我们一起进步&#xff01;&#x1f604; 如果文章对你有帮助的话&#xff0c; 欢迎评论 &#x1f4ac;点赞&#x1f4…

【GESP】2023年03月图形化二级 -- 绘制图形

文章目录 绘制图形1. 准备工作2. 功能实现3. 设计思路与实现&#xff08;1&#xff09;角色、舞台背景设置a. 角色设置b. 舞台背景设置 &#xff08;2&#xff09;脚本编写a. 角色&#xff1a;小猫 4. 评分标准 绘制图形 1. 准备工作 &#xff08;1) 隐藏默认角色小猫。 2. 功…

【Redis入门】 —— 关于Redis的一点儿知识

&#x1f4a7; 【 R e d i s 入门】——关于 R e d i s 的一点儿知识 \color{#FF1493}{【Redis入门】 —— 关于Redis的一点儿知识} 【Redis入门】——关于Redis的一点儿知识&#x1f4a7; &#x1f337; 仰望天空&#xff0c;妳我亦是行人.✨ &#x1f984; 个人主页…

2023年华中杯数学建模B题小学数学应用题相似性度量及难度评估解题全过程文档及程序

2023年华中杯数学建模 B题 小学数学应用题相似性度量及难度评估 原题再现 某 MOOC 在线教育平台希望能够进行个性化教学&#xff0c;实现用户自主学习。在用户学习时&#xff0c;系统从题库中随机抽取若干道与例题同步的随堂测试题&#xff0c;记录、分析学生的学习和答题信息…

深入Vite:再谈ESM的高阶特性

谈到前端模块化的发展历史&#xff0c;就一定不会漏掉ESM&#xff0c;除此之外&#xff0c;还有大家熟知的CommonJS、AMD、CMD以及ES6等。目前&#xff0c; ESM 已经逐步得到各大浏览器厂商以及 Node.js 的原生支持&#xff0c;正在成为主流前端模块化方案。 而 Vite 本身就是…

chatgpt赋能python:Python除零错误:原因,解决办法和实践建议

Python 除零错误&#xff1a;原因&#xff0c;解决办法和实践建议 介绍 Python 作为一门广泛使用的高级编程语言&#xff0c;它的强大之处就体现在它的简洁性、可读性和易用性上。但是在实践中&#xff0c;有时候我们会遇到一些让我们不得不头痛的问题&#xff0c;其中之一就…

(0017) H5-vue创建项目vue init webpack

1、初始化项目 1、vue 命令讲解 vue list &#xff1a;查看可以基于那些模板创建vue应用vue init <template-name> <project-name>init&#xff1a;表示要用vue-cli来初始化项目 <template-name>&#xff1a;表示模板名称&#xff0c;vue-cli官方提供的5种…

【LeetCode】218. 天际线问题

218. 天际线问题&#xff08;困难&#xff09; 思路 题意转化 完整思路分析 multiset的使用 multiset 是关联容器的一种&#xff0c;是排序好的集合&#xff08;元素默认升序&#xff09;&#xff0c;并且允许有相同的元素。 不能直接修改 multiset 容器中元素的值。因…

柯美658 558 458 308 554 364等报错故障代码C2152,C2153,C2154,C2155,C2156 C2253.C2254维修

代码基本都是转印带故障代码,转印带有两个传感器是检测转印带工作和没有工作时加压有没有归位的,传感器基本不会坏,更多的情况是因为转印带上的废粉落在了传感器上导致传感器故障,清洁即可。

剑指offer--JZ24 反转链表

反转链表需要三个指针&#xff0c;一个保留前一个结点的指针&#xff0c;一个后移指针&#xff0c;一个当前指针。C语言版本代码如下&#xff1a; #include <stdio.h> #include <stdlib.h>// 单链表节点结构定义 struct ListNode {int val;struct ListNode* next;…

用acsii , unicode,utf-8讨论为什么采用中文编程不行

一、背景介绍 很多刚接触计算机的同学&#xff0c;可能会发出一个疑问&#xff0c;为什么不能直接使用中文编程&#xff1f; 要了解这个问题&#xff0c;还得从计算机的起源说起&#xff01; 在计算机软件里面&#xff0c;一切的信息都可以用 1 和 0 来表示&#xff08;严格…