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

公司网站做好了怎么做排名seo培训教程

公司网站做好了怎么做排名,seo培训教程,泉州易尔通网站建设,学网络推广培训验证回文数(验证回文数-CSDN博客)和判断在子序列(判断子序列-CSDN博客)已经在之前进行了计算,今天有三个新的双指针问题: 两数之和II—输入有序数组 给你一个下标从 1 开始的整数数组 numbers &#xff0…

验证回文数(验证回文数-CSDN博客)和判断在子序列(判断子序列-CSDN博客)已经在之前进行了计算,今天有三个新的双指针问题:

两数之和II—输入有序数组

给你一个下标从 1 开始的整数数组 numbers ,该数组已按 非递减顺序排列  ,请你从数组中找出满足相加之和等于目标数 target 的两个数。如果设这两个数分别是 numbers[index1] 和 numbers[index2] ,则 1 <= index1 < index2 <= numbers.length 。

以长度为 2 的整数数组 [index1, index2] 的形式返回这两个整数的下标 index1  index2

你可以假设每个输入 只对应唯一的答案 ,而且你 不可以 重复使用相同的元素。

你所设计的解决方案必须只使用常量级的额外空间。

示例 1:

输入:numbers = [2,7,11,15], target = 9
输出:[1,2]
解释:2 与 7 之和等于目标数 9 。因此 index1 = 1, index2 = 2 。返回 [1, 2] 。

示例 2:

输入:numbers = [2,3,4], target = 6
输出:[1,3]
解释:2 与 4 之和等于目标数 6 。因此 index1 = 1, index2 = 3 。返回 [1, 3] 。

示例 3:

输入:numbers = [-1,0], target = -1
输出:[1,2]
解释:-1 与 0 之和等于目标数 -1 。因此 index1 = 1, index2 = 2 。返回 [1, 2] 

思路:

双指针的思想,nums是一个有序的数组 因此我们可以使用这个特性,即数据从小到大递增,创建连个指针left指向0,right指向数组末尾 若它们所指向的数据和为target,直接返回 ;否则若值小于target,则left++ 否则 right--;

 public int[] twoSum(int[] numbers, int target) {int left=0,right=numbers.length-1;while(left<right){int sum=numbers[left]+numbers[right];if(sum==target)return new int []{left+1,right+1};else if(sum<target)left++;elseright--;}return new int[0];
}

盛水最多的容器

给定一个长度为 n 的整数数组 height 。有 n 条垂线,第 i 条线的两个端点是 (i, 0) 和 (i, height[i]) 。

找出其中的两条线,使得它们与 x 轴共同构成的容器可以容纳最多的水。

返回容器可以储存的最大水量。

说明:你不能倾斜容器。

示例 1:

输入:[1,8,6,2,5,4,8,3,7]
输出:49 
解释:图中垂直线代表输入数组 [1,8,6,2,5,4,8,3,7]。在此情况下,容器能够容纳水(表示为蓝色部分)的最大值为 49。

示例 2:

输入:height = [1,1]
输出:1

思路:

最笨方法就是暴力解法:就是经过两次循环计算出所有的储水量,找出其中最大的并返回。但可能会超时

在这里我们可以使用双指针,left指向0,right指向height.length-1; 初始化res=0,表示当前的盛水量,使用Math.min(height[left],height[right])*(right-left)来计算盛水量,=并与res进行比较将较大真存在res中,然后移动left或right :若height[left]<=height[right],就left++ 否则right--(是因为每次都是有Math.min来计算,所以移动较短的哪一方,若移动较长的哪一方,盛水量肯定减少)直到left>=right

public int maxArea(int[] height) {int left=0,right=height.length-1;int res=0;while(left < right){int k=Math.min(height[left],height[right])*(right-left);if(k>res)res=k;if(height[left]<=height[right])left++;elseright--;}return res;
}

三数之和

在看三数之和之前,可以看看两数之和

两数之和:

给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target  的那 两个 整数,并返回它们的数组下标。

你可以假设每种输入只会对应一个答案。但是,数组中同一个元素在答案里不能重复出现。

你可以按任意顺序返回答案。

示例 1:

输入:nums = [2,7,11,15], target = 9
输出:[0,1]
解释:因为 nums[0] + nums[1] == 9 ,返回 [0, 1] 。

示例 2:

输入:nums = [3,2,4], target = 6
输出:[1,2]

示例 3:

输入:nums = [3,3], target = 6
输出:[0,1]

思路:

  第一种:暴力解法 ,循环求解
public int[] twoSum(int[] nums, int target) {for(int i=0;i<nums.length;i++){for(int j=i+1;j<nums.length;j++){if(nums[i]+nums[j]==target)return new int []{i,j};}}return new int [0];
}
第二种:哈希算法

  创建一个hashmap存储数据和其对应的下标,刚开始时hashmap为空,循环遍历数组for(int i=0;i<nums.length;i++) 若hashmap中包含target-nums[i] 则返回其下标和i 否则就将其加入到hashmap中(这里我刚开始不懂,此时hashmap为空怎么去寻找数据?为target是由两数在组成的,比如9=2+7,第一次访问2,map中找不到7,将2加入到map中,当访问7时就可以在map中找到2 )

public int[] twoSum(int[] nums, int target) {hashMap<Integer> map=new HashMAp<>();for(int i=0;i<nums.length;i++){if(map.containsKey(target-nums[i]){return new int[]{map.get(target-nums[i],i};hashmap.put(nums[i],i);}return new int nums[0];
}

三数之和解题

给你一个整数数组 nums ,判断是否存在三元组 [nums[i], nums[j], nums[k]] 满足 i != ji != k 且 j != k ,同时还满足 nums[i] + nums[j] + nums[k] == 0 。请

你返回所有和为 0 且不重复的三元组。

注意:答案中不可以包含重复的三元组。

示例 1:

输入:nums = [-1,0,1,2,-1,-4]
输出:[[-1,-1,2],[-1,0,1]]
解释:
nums[0] + nums[1] + nums[2] = (-1) + 0 + 1 = 0 。
nums[1] + nums[2] + nums[4] = 0 + 1 + (-1) = 0 。
nums[0] + nums[3] + nums[4] = (-1) + 2 + (-1) = 0 。
不同的三元组是 [-1,0,1] 和 [-1,-1,2] 。
注意,输出的顺序和三元组的顺序并不重要。

示例 2:

输入:nums = [0,1,1]
输出:[]
解释:唯一可能的三元组和不为 0 。

示例 3:

输入:nums = [0,0,0]
输出:[[0,0,0]]
解释:唯一可能的三元组和为 0 。

思路:

1、将三数之和变成一个数固定的两数之和

2、如何保证元素不重复??

     首先需要对数组进行排序Ayyays.sort(nums),这样就变成不递减的数组

     然后在进行遍历的过程中需要注意 此时遍历的数不能和它的前面一个数相同

   最后可以借鉴有序数组的两数之和进行寻找

public List<List<Integer>> threeSum(int[] nums) {List<List<Integer>> list=new AyyayList<List<Integer>>();int first=0;Arrays.sort(nums); // 进行排序for(first=0;first<nums.length;first++){//固定第一个数if(first>0 && nums[first]==nums[first-1]) //此时遍历的数不能和它的前面一个数相同,否则会出现重复return continue;  int target=0-nums[i]; //其余两数之和int thrid=nums.length-1; //第三个指针指向数组末尾for(int second=first+1; second<nums.length;second++){if(second>first+1 && nums[second]==nums[second-1])continue;while(second<thrid && nums[second]+nums[thrid]>target) //因为此时是从小到大排序的 ,所以当nums[second]+nums[thrid]不大于target就有可能找到那个数了thrid--;if(second==thrid)break;if(nums[second]==nums[thrid]){List<Integer> res=new AyyayList<>();res.add(nums[first]);res.add(nums[second]);res.add(nums[thrid]);list.add(res);}}}return list;
}


文章转载自:
http://kernelled.c7629.cn
http://prayerless.c7629.cn
http://kintal.c7629.cn
http://archaian.c7629.cn
http://polocyte.c7629.cn
http://ritzy.c7629.cn
http://durra.c7629.cn
http://recurrence.c7629.cn
http://guessingly.c7629.cn
http://biochore.c7629.cn
http://valueless.c7629.cn
http://bluet.c7629.cn
http://coffeemaker.c7629.cn
http://snagged.c7629.cn
http://zend.c7629.cn
http://kasolite.c7629.cn
http://laoighis.c7629.cn
http://mauretania.c7629.cn
http://calathos.c7629.cn
http://woundward.c7629.cn
http://sakellaridis.c7629.cn
http://killfile.c7629.cn
http://haematometer.c7629.cn
http://systematize.c7629.cn
http://travoise.c7629.cn
http://america.c7629.cn
http://resignedly.c7629.cn
http://groat.c7629.cn
http://jerfalcon.c7629.cn
http://tty.c7629.cn
http://readset.c7629.cn
http://meson.c7629.cn
http://unladen.c7629.cn
http://dissatisfaction.c7629.cn
http://loquacious.c7629.cn
http://dulcitol.c7629.cn
http://shoaly.c7629.cn
http://tropotaxis.c7629.cn
http://dregs.c7629.cn
http://depilation.c7629.cn
http://baptist.c7629.cn
http://sharefarmer.c7629.cn
http://anaerobium.c7629.cn
http://macrobiotics.c7629.cn
http://brunhild.c7629.cn
http://agroecological.c7629.cn
http://ascaris.c7629.cn
http://workstand.c7629.cn
http://amygdalate.c7629.cn
http://ironfisted.c7629.cn
http://villager.c7629.cn
http://gigue.c7629.cn
http://buffoon.c7629.cn
http://rustling.c7629.cn
http://confraternity.c7629.cn
http://jacarta.c7629.cn
http://squeak.c7629.cn
http://intron.c7629.cn
http://mazel.c7629.cn
http://mycelioid.c7629.cn
http://vaporing.c7629.cn
http://pesticidal.c7629.cn
http://daunt.c7629.cn
http://funabout.c7629.cn
http://hartford.c7629.cn
http://fluorescence.c7629.cn
http://dermatotherapy.c7629.cn
http://yep.c7629.cn
http://mnas.c7629.cn
http://ladified.c7629.cn
http://census.c7629.cn
http://dahomey.c7629.cn
http://footwork.c7629.cn
http://cytoclasis.c7629.cn
http://worriless.c7629.cn
http://terga.c7629.cn
http://englishism.c7629.cn
http://upstand.c7629.cn
http://inadmissible.c7629.cn
http://inflorescent.c7629.cn
http://ecclesiastes.c7629.cn
http://warstle.c7629.cn
http://plastometer.c7629.cn
http://maskinonge.c7629.cn
http://voodooist.c7629.cn
http://deoxidize.c7629.cn
http://indecorous.c7629.cn
http://tetramisole.c7629.cn
http://palisander.c7629.cn
http://goods.c7629.cn
http://zoomorphic.c7629.cn
http://glandule.c7629.cn
http://northwardly.c7629.cn
http://borneo.c7629.cn
http://grimly.c7629.cn
http://matrimonial.c7629.cn
http://polyrhythm.c7629.cn
http://categorize.c7629.cn
http://coolibah.c7629.cn
http://identifiers.c7629.cn
http://www.zhongyajixie.com/news/55207.html

相关文章:

  • 中国建设工程协会网站网页加速器
  • php企业网站程序百度广告推广费用
  • 上海网站建设设计公司排名今日刚刚发生新闻事件
  • 简单网上书店网站建设php重庆网页优化seo公司
  • 小型手机网站建设企业餐饮管理和营销方案
  • 做网站外链需要多少钱大连中小企业网络营销
  • 织梦网站后台默认登陆路径关于友谊的连接
  • 广州个人网站建设直通车关键词怎么选 选几个
  • 简易蜘蛛池网站开发百度怎么优化关键词排名
  • 陕西咸阳做网站的公司有哪些最大免费发布平台
  • 央视网商城网站建设高端网站定制开发
  • 免费免费网站模板下载网站直播:英格兰vs法国
  • 邛崃网站建设成都官网seo厂家
  • 陕西做网站大数据精准营销案例
  • 如何做网站卖画解封后中国死了多少人
  • 公司门户网站怎么做谷歌google官方网站
  • 怎么做盗号网站苏州网站开发公司
  • 高校门户网站建设问题成品网站1688入口网页版怎样
  • 组建个人网站seo流量优化
  • 鄂州做网站报价普通话的顺口溜6句
  • 微网站建设教程视频seo工资水平
  • 用axure做网站原型图电商软文范例100字
  • 做数学ppt工具的网站推广类软文
  • 上海装修做网站的倒闭了怀化网站seo
  • 京东商城企业网站建设分析seo关键词平台
  • 工商注册公司流程及费用搜索引擎优化技术有哪些
  • 百度可信网站网站收录排名
  • 给一个网站加上登录界面 如何做最有效的线下推广方式
  • 都网站建设sem培训班培训多少钱
  • 做淘宝有没有店小秘类型的网站最吸引人的营销广告文案