当前位置: 首页 > news >正文

门户网站建设公司渠道免费查企业老板的软件

门户网站建设公司渠道,免费查企业老板的软件,太原要做网站的公司,外贸那些网站好用吗文章目录 1.题目2.题目解答1.四数之和题目及题目解析算法学习代码提交 2.长度最小的子数组题目及题目解析滑动窗口的算法学习方法一:单向双指针(暴力解法)方法二:同向双指针(滑动窗口) 代码提交 1.题目 18. 四数之和 - 力扣(LeetCode&#x…

在这里插入图片描述

文章目录

  • 1.题目
  • 2.题目解答
    • 1.四数之和
      • 题目及题目解析
      • 算法学习
      • 代码提交
    • 2.长度最小的子数组
      • 题目及题目解析
      • 滑动窗口的算法学习
        • 方法一:单向双指针(暴力解法)
        • 方法二:同向双指针(滑动窗口)
      • 代码提交

1.题目

  1. 18. 四数之和 - 力扣(LeetCode)
  2. 209. 长度最小的子数组 - 力扣(LeetCode)

2.题目解答

1.四数之和

题目及题目解析

1733707634422

算法学习

1733710613086

1733710932483

去重:

  1. 外层固定的数要跳过相同的数
  2. 内层固定的数也要跳过相同的数
  3. left和right也要跳过相同的数

这部分的代码如下:

int i = 0;
while (i < nums.size() - 1)
{int j = i + 1;while (j < nums.size() - 1){int left = j + 1;int right = nums.size() - 1;long long int tmp = (long long int)target - nums[i] - nums[j];while (left < right){if (nums[left] + nums[right] > tmp){right--;}else if (nums[left] + nums[right] < tmp){left++;}else{v.push_back(nums[i]);v.push_back(nums[left]);v.push_back(nums[right]);v.push_back(nums[j]);vv.push_back(v);v.clear();left++;right--;while (left < right && nums[left] == nums[left - 1]){left++;}while (left < right && nums[right] == nums[right + 1]){right--;}}}j++;while (j < nums.size() - 1 && nums[j] == nums[j - 1]){j++;}}i++;while (i < nums.size() - 1 && nums[i] == nums[i - 1]){i++;}
}

代码提交

class Solution {
public:vector<vector<int>> fourSum(vector<int>& nums, int target) {vector<vector<int>> vv;vector<int> v;sort(nums.begin(),nums.end());int i = 0;while(i<nums.size()-1){int j =i+1;while(j<nums.size()-1){int left =j+1;int right=nums.size()-1;long long int tmp = (long long int)target-nums[i]-nums[j];while(left<right){if(nums[left]+nums[right]>tmp){right--;}else if(nums[left]+nums[right]<tmp){left++;}else{v.push_back(nums[i]);v.push_back(nums[left]);v.push_back(nums[right]);v.push_back(nums[j]);vv.push_back(v);v.clear();left++;right--;while(left<right&&nums[left]==nums[left-1]){left++;}while(left<right&&nums[right]==nums[right+1]){right--;}}}j++;while(j<nums.size()-1&&nums[j]==nums[j-1]){j++;}}i++;while(i<nums.size()-1&&nums[i]==nums[i-1]){i++;}}return vv;}
};

2.长度最小的子数组

题目及题目解析

1733713068683

滑动窗口的算法学习

方法一:单向双指针(暴力解法)

直接定义两个指针从前向后一次遍历,将所有的结果列举出来,直接进行求解

解法如下:

class Solution {
public:int minSubArrayLen(int target, vector<int>& nums) {int ret = INT_MAX;int n = nums.size();// 枚举出所有满⾜和⼤于等于 target 的⼦数组[start, end]// 由于是取到最⼩,因此枚举的过程中要尽量让数组的⻓度最⼩// 枚举开始位置for (int start = 0; start < n; start++) {int sum = 0; // 记录从这个位置开始的连续数组的和// 寻找结束位置for (int end = start; end < n; end++) {sum += nums[end]; // 将当前位置加上if (sum >= target) // 当这段区间内的和满⾜条件时{// 更新结果,start 开头的最短区间已经找到ret = min(ret, end - start + 1);break;}}}// 返回最后结果return ret == INT_MAX ? 0 : ret;}
};

1733726185959

方法二:同向双指针(滑动窗口)

我们在使用暴力解法的时候发现

right指针没有必要每次都进行回退

可以让其一直保持在原有位置不变:

1733726477465

1733726690257

这也就是滑动窗口

当暴力解法两个指针都不回退且要对一部分的区间进行管理,就可以使用双指针解法

解法步骤如下:

初始化部分:

  1. 初始化窗口

    1733726928339

循环部分:

  1. 进窗口

    1733727292329

  2. 判断是否出窗口(同时要记录值)

    1733727417480

  3. 进窗口

    1733727664312

  4. 判断是否出窗口(同时要记录值)

    1733727797087

    重复这两个步骤就可以得出我们想要的结果了

    写成代码如下:

    int left = 0, right = 0;
    int sum = 0;
    int len = INT_MAX;
    for (;right < nums.size();right++)
    {sum += nums[right];while (sum >= target){len = min(len, right - left + 1);sum -= nums[left++];}
    }
    

代码提交

class Solution {
public:int minSubArrayLen(int target, vector<int>& nums) {int left =0,right =0;int sum =0;int len = INT_MAX;for(;right<nums.size();right++){sum += nums[right];while(sum>=target){len = min(len,right-left+1);sum -= nums[left++];}}return len==INT_MAX?0:len;}
};
http://www.yayakq.cn/news/117518/

相关文章:

  • 免费做电子书的网站苏州电商网站建设
  • 下载asp做网站无极官方网站下载
  • 杭州外贸网站建设公司申跃应用软件开发包括什么
  • 小程序软件制作网站电子商务网站建设如何实施
  • 南宁网站建设平台网站建设中页面
  • 网站不能访问如何做冗余wordpress引用群晖文件夹
  • 南通做网站公司哪家好中国三大生产建设兵团
  • 网站建设策划方案书wordpress apple4us
  • 永州高端网站建设网站开发后台框架
  • 网站建设维护专员金蝶软件官网
  • 免费网站软件app网站建设推广信息
  • 网站开发的主要工作wordpress开发手册中文版
  • 怎么修改网站内容做健身类小程序的网站
  • 网站开发的英文文献网站建设行业分析报告
  • 公司网站功能性建设有哪些乌海市网站建设
  • 个人网站的设计师wordpress 页面 编辑
  • 网站做后台教程wordpress 另类加速
  • 做童车外贸上哪个网站六安市网站建设
  • 万能网页视频下载器淄博网站seo公司
  • 做网站要服务器吗石家庄视频网站建设公司
  • 网站 第三方登录做网站的前端是做什么
  • 建设银行官网的网站首页sqlite 做网站
  • c 语言做网站网站建设的优缺点
  • dedecms做的网站手机上看图片变形哪些网站可以做外链
  • wp网站打开太慢怎么做优化wordpress考试主题
  • 孟村县做网站价格通城做网站的
  • 屏蔽网站ip域名与空间购买后怎么做网站
  • python可以做网站枫树seo网
  • 海淀专业企业网站建设qq是谁的公司开发的
  • 华为网站建设费用wordpress all in one