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

免费手机网站源码下载网站logo代码

免费手机网站源码下载,网站logo代码,邯郸网站设计培训机构,做博客的网站有哪些功能盛水最多的容器 (1)暴力解法 算法思路:我们枚举出所有的容器大小,取最大值即可。 容器容积的计算方式: 设两指针 i , j ,分别指向水槽板的最左端以及最右端,此时容器的宽度为 j - i 。由于容器…

在这里插入图片描述
在这里插入图片描述
盛水最多的容器

(1)暴力解法

  算法思路:我们枚举出所有的容器大小,取最大值即可。

  容器容积的计算方式:

  设两指针 i , j ,分别指向水槽板的最左端以及最右端,此时容器的宽度为 j - i 。由于容器的高度由两板中的较短的板决定,因此可得容积公式 :
v = (j - i) * min( height[i] , height[j] );

class Solution {
public:int maxArea(vector<int>& height) {int n=height.size();int ret=0;//枚举出所有的容器大小for(int i=0;i<n;i++){for(int j=i+1;j<n;j++){//计算当前的容器容量int v=(j-i)*(min(height[i],height[j]));ret=max(ret,v);//取最大容量的容器}}return ret;}
};

在这里插入图片描述

  当然由于两次遍历数组,所以时间复杂度为O(N2),会超时。


(2)对撞指针

  算法思路:我们设置两个指针left、right分别指向容器的两个端点(因为这里的是数组,数组在内存中的储存是连续的,而且数组是通过它们的下表访问,所有我们可以把数组下标看成是指针进行操作)不断修改左右的端点来获得容器的最大容量。

  容器的左边界为 height[left] ,右边界为 height[right] 。

  我们假设「左边边界」小于「右边边界」。

  水的容积会有如下变化形式:

  首先容器的宽度⼀定变小。由于左边界较小,决定了水的高度。如果改变左边界,新的水面高度不确定,但是⼀定不会超过右边的柱子高度,因此容器的容积可能会增大或者减小。

  但是如果改变右边界,无论右边界移动到哪⾥,新的水面的高度⼀定不会超过左边界,也就是现在左边界的所在的水面高度,但是由于容器的宽度减小,因此容器的容积一定会变小。

  综上,我们不断选取左右两个边界中的较大边界,以保留当下的最有解,不断的 left++ 或right–,直到left和right相遇。

class Solution {
public:int maxArea(vector<int>& height) {int left=0;int right=height.size()-1;int ret=0;//循环条件为右边界大于左边界while(left<right){//计算当前容器的容量int v=(right-left)*(min(height[left],height[right]));ret=max(v,ret);//不断更新容器的最大容量if(height[left]>height[right]) right--;//不断更新左右高度else left++;                           //保留高的,舍弃较矮的高}return ret;}
};

时间复杂度:O(N)
在这里插入图片描述


在这里插入图片描述

和为s的两个数字

  和两数之和不同的是,该数组中的元素是有序的,而且使用暴力解法会超时。

(1)对撞指针

这里有三种情况:

  当 nums[left] + nums[right] == target时,说明找到结果,记录结果,并且返回;

  当 nums[left] + nums[right] < target 时,此时 nums[right] 相当于是 nums[left] 能碰到的最大值。如果此时不符合要求,说明我们需要增加这两个数之和,所以我们让left++,再取更大的数,以来靠近我们的目标和。

  当 nums[left] + nums[right] > target 时,说明我们所取的两数较大,所以我们应该减小这两个数之和,让right–,以此使得两数的总和变小,以此来靠近我们的目标和。不断比较下⼀组数据,直至两数和和目标和相等。

class Solution {
public:vector<int> twoSum(vector<int>& nums, int target) {int left=0;int right=nums.size()-1;while(left<right){//如果两数和等于目标值,直接返回if(nums[left]+nums[right]==target){return {nums[left],nums[right]};}//如果两数和大于目标值,right--else if(nums[left]+nums[right]>target){right--;}//如果两数和小于目标值,left++    else{left++;}}//照顾编译器,返回一个不存在的数组return {-1141514};}
};

时间复杂度:O(N)
在这里插入图片描述

http://www.yayakq.cn/news/818570/

相关文章:

  • 网站后台地址修改免费网站建设程序
  • 刷单网站搭建wordpress打印功能
  • pc端网站未来国内阿里网站建设
  • 公司注销预审在什么网站做应聘网站开发的自我介绍
  • 谷歌网页版入口在线seo快速整站上排名教程
  • 建投五公司网站推广联盟网站怎么做
  • 网站开发一定要用框架吗专业的东莞网站设计
  • 杭州建设网站免费男科医院在线咨询预约
  • 柳州企业网站建设公司汽车类网站设计规划
  • 做网站然后卖.me做社区网站
  • 做网站 每月赚 钱即墨网站优化
  • 网络电子商务购物网站cd-wordpress
  • 东鹏拼奖网站怎么做外包seo服务收费标准
  • 广州做外贸网站公司邯郸seo排名
  • 世界网站制作产品网站推广方案
  • 合肥金融网站开发如何做公司简介介绍
  • 自建站公司淘宝客如何免费做网站
  • 华池网站建设柏乡网站建设
  • 网站好坏微信免费推广平台
  • 郑州汉狮做网站网络公司武昌建设局网站
  • 天津市建设与管理局网站网站查询平台官网
  • 动漫设计是什么系统优化大师免费版
  • 网站功能简介食品网站网页设计
  • 域名注册以后如何建站邢台网站改版定制
  • 手机网站主页阿里云做网站用哪个镜像
  • 建站 报价邢台wap网站建设报价
  • 网站注册流程和费用众筹网站怎么做
  • 湖北省住房城乡建设厅网站网站设计字体最好用
  • 官方网站建设推广appstore下载免费软件
  • 网站建设合同百度文库一级a做爰片免费网站国语