【C++代码】接雨水,最近的更大的元素,柱状图中的最大矩阵,单调栈--代码随想录

news2025/1/13 10:33:40

题目:每日温度

  • 给定一个整数数组 temperatures ,表示每天的温度,返回一个数组 answer ,其中 answer[i] 是指对于第 i 天,下一个更高温度出现在几天后。如果气温在这之后都不会升高,请在该位置用 0 来代替。

  • 暴力解法,两层for循环,去更新结果数组

    • class Solution {
      public:
          vector<int> dailyTemperatures(vector<int>& temperatures) {
              vector<int> res(temperatures.size());
              for(int i=0;i<temperatures.size();i++){
                  int dis=0;
                  bool flag=true;
                  for(int j=i+1;j<temperatures.size();j++){
                      if(temperatures[i]>=temperatures[j]){
                          dis++;
                      }else{
                          dis++;
                          flag = false;
                          break;
                      }
                  }
                  if(flag){
                      dis=0;
                  }
                  res[i] = dis;
              }
              return res;
          }
      };//超时
      
  • 对于温度列表中的每个元素 temperatures[i],需要找到最小的下标 j,使得 i < j 且 temperatures[i] < temperatures[j]。由于温度范围在 [30, 100] 之内,因此可以维护一个数组 next 记录每个温度第一次出现的下标。数组 next 中的元素初始化为无穷大,在遍历温度列表的过程中更新 next 的值。

  • 反向遍历温度列表。对于每个元素 temperatures[i],在数组 next 中找到从 temperatures[i] + 1 到 100 中每个温度第一次出现的下标,将其中的最小下标记为 warmerIndex,则 warmerIndex 为下一次温度比当天高的下标。如果 warmerIndex 不为无穷大,则 warmerIndex - i 即为下一次温度比当天高的等待天数,最后令 next[temperatures[i]] = i。

  • class Solution {
    public:
        vector<int> dailyTemperatures(vector<int>& temperatures) {
            int n=temperatures.size();
            vector<int> ans(n),next(101,INT_MAX);
            for(int i=n-1;i>=0;i--){
                int index=INT_MAX;
                for(int t = temperatures[i]+1;t<=100;++t){
                    index = min(index,next[t]);
                }
                if(index!=INT_MAX){
                    ans[i]=index-i;
                }
                next[temperatures[i]]=i;
            }
            return ans;
        }
    };
    
  • 时间复杂度:O(nm)),其中 n 是温度列表的长度,m 是数组 next 的长度,在本题中温度不超过 100,所以 m 的值为 100。反向遍历温度列表一遍,对于温度列表中的每个值,都要遍历数组 next 一遍。空间复杂度:O(m),其中 m 是数组 next 的长度。除了返回值以外,需要维护长度为 m 的数组 next 记录每个温度第一次出现的下标位置。

  • 通常是一维数组,要寻找任一个元素的右边或者左边第一个比自己大或者小的元素的位置,此时我们就要想到可以用单调栈了。时间复杂度为O(n)。单调栈的本质是空间换时间,因为在遍历的过程中需要用一个栈来记录右边第一个比当前元素高的元素,优点是整个数组只需要遍历一次。更直白来说,就是用一个栈来记录我们遍历过的元素,因为我们遍历数组的时候,我们不知道之前都遍历了哪些元素,以至于遍历一个元素找不到是不是之前遍历过一个更小的,所以我们需要用一个容器(这里用单调栈)来记录我们遍历过的元素。

    • 单调栈里存放的元素是什么?单调栈里只需要存放元素的下标i就可以了,如果需要使用对应的元素,直接T[i]就可以获取。
    • 单调栈里元素是递增呢? 还是递减呢?这里我们要使用递增循序(再强调一下是指从栈头到栈底的顺序),因为只有递增的时候,栈里要加入一个元素i的时候,才知道栈顶元素在数组中右面第一个比栈顶元素大的元素是i。即:如果求一个元素右边第一个更大元素,单调栈就是递增的,如果求一个元素右边第一个更小元素,单调栈就是递减的。
  • class Solution {
    public:
        vector<int> dailyTemperatures(vector<int>& temperatures) {
            stack<int> st;
            vector<int> res(temperatures.size(),0);
            st.push(0);//0表示下标
            for(int i=1;i<temperatures.size();i++){
                if(temperatures[i]<temperatures[st.top()]){
                    st.push(i);
                }else if(temperatures[i]==temperatures[st.top()]){
                    st.push(i);
                }else{
                    while(!st.empty() && temperatures[i] > temperatures[st.top()]){
                        res[st.top()] = i-st.top();
                        st.pop();
                    }
                    st.push(i);
                }
            }
            return res;
        }
    };
    
  • 时间复杂度:O(n);空间复杂度:O(n)

题目:下一个更大元素 I

  • nums1 中数字 x下一个更大元素 是指 xnums2 中对应位置 右侧第一个x 大的元素。给你两个 没有重复元素 的数组 nums1nums2 ,下标从 0 开始计数,其中nums1nums2 的子集。对于每个 0 <= i < nums1.length ,找出满足 nums1[i] == nums2[j] 的下标 j ,并且在 nums2 确定 nums2[j]下一个更大元素 。如果不存在下一个更大元素,那么本次查询的答案是 -1 。返回一个长度为 nums1.length 的数组 ans 作为答案,满足 ans[i] 是如上所述的 下一个更大元素

  • 暴力解法,,两层for循环

    • class Solution {
      public:
          vector<int> nextGreaterElement(vector<int>& nums1, vector<int>& nums2) {
              vector<int> res(nums1.size(),-1);
              for(int i=0;i<nums1.size();i++){
                  bool flag = false;
                  for(int j=0;j<nums2.size();j++){
                      if(nums1[i]==nums2[j]){
                          flag = true;
                      }
                      if(flag && nums1[i]<nums2[j]){
                          res[i] = nums2[j];
                          break;
                      }
                  }
              }
              return res;
          }
      };
      
  • 从题目示例中我们可以看出最后是要求nums1的每个元素在nums2中下一个比当前元素大的元素,那么就要定义一个和nums1一样大小的数组result来存放结果。题目说如果不存在对应位置就输出 -1 ,所以result数组如果某位置没有被赋值,那么就应该是是-1,所以就初始化为-1。

  • 在遍历nums2的过程中,我们要判断nums2[i]是否在nums1中出现过,因为最后是要根据nums1元素的下标来更新result数组。没有重复元素,我们就可以用map来做映射了。根据数值快速找到下标,还可以判断nums2[i]是否在nums1中出现过。

  • 栈头到栈底的顺序,要从小到大,也就是保持栈里的元素为递增顺序。只要保持递增,才能找到右边第一个比自己大的元素。接下来就要分析如下三种情况,一定要分析清楚。

    • 情况一:当前遍历的元素T[i]小于栈顶元素T[st.top()]的情况;此时满足递增栈(栈头到栈底的顺序),所以直接入栈。
    • 情况二:当前遍历的元素T[i]等于栈顶元素T[st.top()]的情况;
    • 情况三:当前遍历的元素T[i]大于栈顶元素T[st.top()]的情况:此时如果入栈就不满足递增栈了,这也是找到右边第一个比自己大的元素的时候。判断栈顶元素是否在nums1里出现过,(注意栈里的元素是nums2的元素),如果出现过,开始记录结果。
  • class Solution {
    public:
        vector<int> nextGreaterElement(vector<int>& nums1, vector<int>& nums2) {
            stack<int> st;
            vector<int> res(nums1.size(),-1);
            if(nums1.size()==0){
                return res;
            }
            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){
                            int index = umap[nums2[st.top()]];
                            res[index] = nums2[i];
                        }
                        st.pop();
                    }
                    st.push(i);
                }
            }
            return res;
        }
    };
    

题目:下一个更大元素 II

  • 给定一个循环数组 numsnums[nums.length - 1] 的下一个元素是 nums[0] ),返回 nums 中每个元素的 下一个更大元素 。数字 x下一个更大的元素 是按数组遍历顺序,这个数字之后的第一个比它更大的数,这意味着你应该循环地搜索它的下一个更大的数。如果不存在,则输出 -1

  • 直接把两个数组拼接在一起,然后使用单调栈求下一个最大值不就行了!这样做确实可以!

  • 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> res(nums.size(),-1);
            if(nums.size()==0){
                return res;
            }
            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()]){
                        res[st.top()] = nums[i];
                        st.pop();
                    }
                    st.push(i);
                }
            }
            res.resize(nums.size()/2);
            return res;
        }
    };
    
  • 这种写法确实比较直观,但做了很多无用操作,例如修改了nums数组,而且最后还要把result数组resize回去。resize倒是不费时间,是O(1)的操作,但扩充nums数组相当于多了一个O(n)的操作。

    • class Solution {
      public:
          vector<int> nextGreaterElements(vector<int>& nums) {
              int len = nums.size();
              vector<int> res(len,-1);
              if(len == 0){
                  return res;
              }
              stack<int> st;
              st.push(0);
              for(int i=1;i<len*2;i++){
                  if(nums[i % len] < nums[st.top()]){
                      st.push(i%len);
                  }else if(nums[i%len] == nums[st.top()]){
                      st.push(i%len);
                  }else{
                      while(!st.empty() && nums[i%len]>nums[st.top()]){
                          res[st.top()]=nums[i%len];
                          st.pop();
                      }
                      st.push(i%len);
                  }
              }
              return res;
          }
      };
      

题目:接雨水

  • 给定 n 个非负整数表示每个宽度为 1 的柱子的高度图,计算按此排列的柱子,下雨之后能接多少雨水。

  • 本题暴力解法也是也是使用双指针。首先要明确,要按照行来计算,还是按照列来计算。

    • 在这里插入图片描述
  • 首先,**如果按照列来计算的话,宽度一定是1了,我们再把每一列的雨水的高度求出来就可以了。**可以看出每一列雨水的高度,取决于,该列 左侧最高的柱子和右侧最高的柱子中最矮的那个柱子的高度。

  • 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 rH=height[i];
                int lH= height[i];
                for(int r=i+1;r<height.size();r++){
                    if(height[r]>rH){
                        rH = height[r];
                    }
                }
                for(int l=i-1;l>=0;l--){
                    if(height[l]>lH){
                        lH = height[l];
                    }
                }
                int h=min(rH,lH) - height[i];
                if(h>0){
                    sum+=h*1;
                }
            }
            return sum;
        }
    };//超时
    
  • 因为每次遍历列的时候,还要向两边寻找最高的列,所以时间复杂度为O(n^2),空间复杂度为O(1)。双指针法可以优化

    • 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(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(maxright[i+1],height[i]);
              }
              int sum=0;
              for(int i=0;i<size;i++){
                  int count=min(maxleft[i],maxright[i])-height[i];
                  if(count>0){
                      sum +=count;
                  }
              }
              return sum;
          }
      };
      
  • 通常是一维数组,要寻找任一个元素的右边或者左边第一个比自己大或者小的元素的位置,此时我们就要想到可以用单调栈了。而接雨水这道题目,我们正需要寻找一个元素,右边最大元素以及左边最大元素,来计算雨水面积。

  • 首先单调栈是按照行方向来计算雨水,使用单调栈内元素的顺序,从栈头(元素从栈头弹出)到栈底的顺序应该是从小到大的顺序。因为一旦发现添加的柱子高度大于栈头元素了,此时就出现凹槽了,栈头元素就是凹槽底部的柱子,栈头第二个元素就是凹槽左边的柱子,而添加的元素就是凹槽右边的柱子。

    • 在这里插入图片描述
  • 遇到相同的元素,更新栈内下标,就是将栈里元素(旧下标)弹出,将新元素(新下标)加入栈中。

  • 栈里要保存什么数值:使用单调栈,也是通过 长 * 宽 来计算雨水面积的。长就是通过柱子的高度来计算,宽是通过柱子之间的下标来计算,那么栈里有没有必要存一个pair<int, int>类型的元素,保存柱子的高度和下标呢。其实不用,栈里就存放下标就行,想要知道对应的高度,通过height[stack.top()] 就知道弹出的下标对应的高度了。

    • class Solution {
      public:
          int trap(vector<int>& height) {
              if(height.size()<=2){
                  return 0;
              }
              stack<int> st;
              st.push(0);
              int sum=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.push(i);
                  }else{
                      while(!st.empty() && height[i] > height[st.top()]){
                          int mid=st.top();
                          st.pop();
                          if(!st.empty()){
                              int h=min(height[st.top()],height[i])-height[mid];
                              int w=i-st.top()-1;
                              sum += h*w;
                          }
                      }
                      st.push(i);
                  }
              }
              return sum;
          }
      };
      
  • 此时大家应该可以发现其实就是**栈顶和栈顶的下一个元素以及要入栈的元素,三个元素来接水!**那么雨水高度是 min(凹槽左边高度, 凹槽右边高度) - 凹槽底部高度,代码为:int h = min(height[st.top()], height[i]) - height[mid];雨水的宽度是 凹槽右边的下标 - 凹槽左边的下标 - 1(因为只求中间宽度),代码为:int w = i - st.top() - 1 ;当前凹槽雨水的体积就是:h * w

题目:柱状图中最大的矩形

  • 给定 n 个非负整数,用来表示柱状图中各个柱子的高度。每个柱子彼此相邻,且宽度为 1 。求在该柱状图中,能够勾勒出来的矩形的最大面积。

  • 暴力求解,超时

    • 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;
          }
      };
      
  • 本题要记录记录每个柱子 左边第一个小于该柱子的下标,而不是左边第一个小于该柱子的高度。

    • class Solution {
      public:
          int largestRectangleArea(vector<int>& heights) {
              int len = heights.size();
              vector<int> minleft(len);
              vector<int> minright(len);
              // 记录每个柱子 左边第一个小于该柱子的下标
              minleft[0]=-1;
              for(int i=1;i<len;i++){
                  int t=i-1;
                  while(t>=0 && heights[t]>=heights[i]){
                      t = minleft[t];
                  }
                  minleft[i] = t;
              }
              minright[len-1]=len;
              for(int i=len-2;i>=0;i--){
                  int t=i+1;
                  while(t<len && heights[t]>=heights[i]){
                      t = minright[t];
                  }
                  minright[i]=t;
              }
              int res=0;
              for(int i=0;i<len;i++){
                  int sum = heights[i]*(minright[i]-minleft[i]-1);
                  res = max(res,sum);
              }
              return res;
          }
      };
      
  • 这里就涉及到了单调栈很重要的性质,就是单调栈里的顺序,是从小到大还是从大到小。因为本题是要找每个柱子左右两边第一个小于该柱子的柱子,所以从栈头(元素从栈头弹出)到栈底的顺序应该是从大到小的顺序!

    • 在这里插入图片描述
  • 只有栈里从大到小的顺序,才能保证栈顶元素找到左右两边第一个小于栈顶元素的柱子。此时大家应该可以发现其实就是栈顶和栈顶的下一个元素以及要入栈的三个元素组成了我们要求最大面积的高度和宽度。主要就是分析清楚如下三种情况:

    • 情况一:当前遍历的元素heights[i]大于栈顶元素heights[st.top()]的情况
    • 情况二:当前遍历的元素heights[i]等于栈顶元素heights[st.top()]的情况
    • 情况三:当前遍历的元素heights[i]小于栈顶元素heights[st.top()]的情况
  • class Solution {
    public:
        int largestRectangleArea(vector<int>& heights) {
            int res=0;
            stack<int> st;
            heights.insert(heights.begin(),0);// 数组头部加入元素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;
                            int h=heights[mid];
                            res=max(w*h,res);
                        }
                    }
                    st.push(i);
                }
            }
            return res;
        }
    };
    

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

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

相关文章

凡人修仙之灵药篇

一、总纲 &#xff08;1&#xff09;药物均来自拼夕夕&#xff0c;我已经买过的&#xff0c;确认都是正版的&#xff0c;不过急需疗伤的还是线下就医吧&#xff0c; 快递一般都是三天到的。 &#xff08;2&#xff09;具有多种并发症建议去就医。 &#xff08;3&#xff09;两…

【公益案例展】 网易“双碳”智控系统——开源开放赋能绿色发展

‍ 网易天工公益案例 本项目案例由网易天工投递并参与数据猿与上海大数据联盟联合推出的 #榜样的力量# 《2023中国数据智能产业最具社会责任感企业》榜单/奖项”评选。 大数据产业创新服务媒体 ——聚焦数据 改变商业 2020年9月中国明确提出2030年“碳达峰”与2060年“碳中和”…

【黑马程序员】SSM框架——MyBatisPlus

文章目录 前言一、MyBatisPlus 简介1. 入门案例1.1 创建新模块1.2 选择需要的技术集1.3 添加 mp 起步依赖1.4 设置 Jdbc 参数1.5 实体类与表结构1.6 定义数据接口1.7 测试功能 2. MyBatisPlus 概述3. MyBatisPlus 特性 二、标准数据层开发1. 标准数据层 CRUD 功能1.1 Lombok1.2…

Educational Codeforces Round 157 (Rated for Div. 2) D. XOR Construction (思维题)

题目 给定长为n-1(n<2e5)的整数序列a&#xff0c;第i个数a[i](0<a[i]<2n) 构造一个长为n的整数序列b&#xff0c;满足&#xff1a; 1. 0到n-1在b数组中每个数恰好出现一次 2. 对于&#xff0c; 题目保证一定有解&#xff0c;有多组时可以输出任意一组 思路来源 …

腾讯云CVM服务器操作系统镜像大全

腾讯云CVM服务器的公共镜像是由腾讯云官方提供的镜像&#xff0c;公共镜像包含基础操作系统和腾讯云提供的初始化组件&#xff0c;公共镜像分为Windows和Linux两大类操作系统&#xff0c;如TencentOS Server、Windows Server、OpenCloudOS、CentOS Stream、CentOS、Ubuntu、Deb…

图及谱聚类商圈聚类中的应用

背景 在O2O业务场景中&#xff0c;有商圈的概念&#xff0c;商圈是业务运营的单元&#xff0c;有对应的商户BD负责人以及配送运力负责任。这些商圈通常是一定地理围栏构成的区域&#xff0c;区域内包括商户和用户&#xff0c;商圈和商圈之间就通常以道路、河流等围栏进行分隔。…

Java连接Redis并操作Redis中的常见数据类型

目录 一. Java连接Redis 1. 导入依赖 2. 建立连接 二. Java操作Redis的常见数据类型存储 1. Redis字符串(String) 2. Redis哈希(Hash) 3. Redis列表&#xff08;List&#xff09; 4. Redis集合&#xff08;Set&#xff09; 一. Java连接Redis 1. 导入依赖 pom依赖…

Linux--线程-条件控制实现线程的同步

1.条件变量 条件变量是线程另一可用的同步机制。条件变量给多个线程提供了一个会合的场所。条件变量与互斥量一起使用时&#xff0c;允许线程以无竞争的方式等待特定的条件发生。 条件本身是由互斥量保护的。线程在改变条件状态前必须首先锁住互斥量&#xff0c;其他线程在获…

基于STM32HAL库(独立看门狗)-简述

目录 概述 一、开发环境 二、STM32CubeMx配置 三、编码 四、运行结果 五、总结 概述 一个成熟靠谱的项目&#xff0c;离不开“看门狗”的必选项&#xff0c;凡是人写的程序多少都会有出现bug的情况&#xff08;或芯片外设受外界干扰导致故障程序卡死、跑飞的情况&#xf…

第二阶段第一章——面向对象

前言 学习了这么久Python&#xff08;呃其实也没多久差不多两周&#xff09;&#xff0c;可能有小伙伴说我废了&#xff0c;两周才学这么点&#xff0c;咋说呢&#xff0c;我曾经也是急于求成&#xff0c;做任何事情都是急于求成&#xff0c;比如我喜欢一个人我就想马上跟她在…

14 _ 排序优化:如何实现一个通用的、高性能的排序函数?

几乎所有的编程语言都会提供排序函数,比如C语言中qsort(),C++ STL中的sort()、stable_sort(),还有Java语言中的Collections.sort()。在平时的开发中,我们也都是直接使用这些现成的函数来实现业务逻辑中的排序功能。那你知道这些排序函数是如何实现的吗?底层都利用了哪种排…

网络攻击的威胁仍在上升、企业该如何解决

近十年来&#xff0c;网络攻击的频率和规模不断增加&#xff0c;对网站和在线资产构成了严重威胁。解决网站被攻击的问题需要采用多层次的安全策略&#xff0c;其中CDN&#xff08;内容分发网络&#xff09;的防护角度发挥了关键作用。本文将通过通俗易懂的方式从CDN的角度分析…

Python语言_matplotlib包_共80种--全平台可用

Python语言_matplotlib包_共80种–全平台可用 往期推荐&#xff1a; Python语言_single_color_共140种–全平台可用 R语言_RColorBrewer包–全平台可用 R语言gplots包的颜色索引表–全平台可用 R语言中的自带的调色板–五种–全平台可用 R语言657中单色colors颜色索引表—全平台…

6 从物理层到MAC层

1、实现局域网中玩游戏 在早期的80后的大学宿舍中&#xff0c;组件一个宿舍的局域网&#xff0c;以便于宿舍内部可以玩游戏. 第一层&#xff08;物理层&#xff09; 1.首先是实现电脑连接电脑&#xff0c;需要依靠网线&#xff0c;有两个头。 2.一头插在一台电脑的网卡上&am…

要做一名成功的测试,首先得会想?

近在做测试时&#xff0c;突然想到了这么个问题——在测试的过程中对某个功能想得越开&#xff0c;测试就完整&#xff0c;就越彻底&#xff01; 当然我们在产生与该功能相关的想象时&#xff0c;其中最关键的是不能脱离需求&#xff0c;不能脱离该软件本身&#xff1b;不然这…

前端的几种网络请求方式

网络请求 node编写接口 这里用到的几个包的作用 express&#xff1a;基于 Node.js 平台&#xff0c;快速、开放、极简的 Web 开发框架&#xff0c;官网&#xff1a;https://www.expressjs.com.cn/cors&#xff1a;用来解决跨域问题body-parser&#xff1a;可以通过 req.body…

Unity中Shader的GI的间接光实现

文章目录 前言一、GI中 间接光照的实现1、看Unity的源码可知&#xff0c;在计算GI的间接光照时&#xff0c;最主要的实现是在UnityGI_Base函数中 二、分析 UnityGI_Base 中实现的功能1、ResetUnityGI的作用2、第一个#if中实现的功能&#xff1a;计算在Distance Shadowmask 中实…

网络资料(忘传了)

1网络分层模型和应用协议 1.1分层模型 1.1.1分层的意义 当遇到一个复杂问题的时候&#xff0c;可以使用分层的思想把问题简单化 比如&#xff0c;你有半杯82年的可乐&#xff0c;想分享给你的朋友王富贵&#xff0c;但你们已经10年没有联系了。要完成这件事&#xff0c;你可…

JavaScript引用数据类型(对象类型)和原始(基本)数据类型特点比较

JavaScript引用数据类型&#xff08;对象类型&#xff09;和原始&#xff08;基本&#xff09;数据类型特点比较 为讲解JavaScript引用数据类型&#xff08;对象类型&#xff09;和原始&#xff08;基本&#xff09;数据类型特点比较&#xff0c;需要先回顾JavaScript数据类型…