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

做网站的经验和体会百度游戏官网

做网站的经验和体会,百度游戏官网,学做网站论坛VIP怎么样,电商的网站怎么做的目录 1.题目链接:611.有效三角形的个数 2.题目描述: 3.解法一:(暴力解法)(会超时): 4.解法二(排序双指针) 1.题目链接:611.有效三角形的个数 2.题目描述: 给定一个包含非负整数的数组 nums &#xf…

目录

1.题目链接:611.有效三角形的个数

2.题目描述:

3.解法一:(暴力解法)(会超时):

4.解法二(排序+双指针)


1.题目链接:611.有效三角形的个数

2.题目描述:
 

给定一个包含非负整数的数组 nums ,返回其中可以组成三角形三条边的三元组个数。

示例 1:

输入: nums = [2,2,3,4]
输出: 3
解释:有效的组合是: 
2,3,4 (使用第一个 2)
2,3,4 (使用第二个 2)
2,2,3

示例 2:

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

3.解法一:(暴力解法)(会超时):

算法思路:
三层for循环枚举出所有的三元组,并且判断是否能构成三角形。

虽然说是暴力求解,但是还是可以优化一下:

判断三角形的优化

  • 如果能构成三角形,需要满足任意两边之和大于第三边。但是实际上只需让较小的两条边之和大于第三边既可。
  • 因此我们可以先将原数组排序,然后从小到大枚举三元组,一方面省去枚举的数量,另一方面方便判断是否能构成三角形。
class Solution
{
public:int triangleNumber(vector<int>& nums){//1.排序sort(nums.begin(), nums.end());int n = nums.size(), ret = 0;//2.从小到大枚举所有的三元组for (int i = 0; i < n; i++){for (int j = i + 1; j < n; j++){for (int k = j + 1; k < n; k++){   //当最小的两个边之和大于第三个边的时候,统计答案if (nums[i] + nums[i] > nums[k])ret++;}}}return ret;}
};

4.解法二(排序+双指针)

算法思路:

先将数组排序。

根据解法一中的优化思想,我们可以固定一个最长边,然后在比这条边小的有序数组中找出一个二元组,使这个二元组之和大于这个最长边。由于数组使有序的,我们可以利用对撞指针来优化。

设最长边枚举到i位置,区间[left,right]是i位置左边的区间(也就是比他小的区间):

  • 如果nums[left] + nums[right] > nums[i]:
    说明[left,right-1]区间上的所有元素均可以与nums[right]构成比nums[i]大的二元组            满足条件的有right - left种                                                                                                  此时right位置的元素的所有情况相当于全部考虑完毕,right--,进入下一轮判断
  • 如果nums[left] + nums[right] <= nums[i]:
    说明left位置的元素是不可能与[left+1,right]位置上的元素构成满足条件的二元组               left位置的元素可以舍去,left++进入下轮循环
class Solution {
public:int triangleNumber(vector<int>& nums) {int sum = 0,n = nums.size();sort(nums.begin(),nums.end());for(int i = n - 1;i>=2;i--){int left = 0,right = i-1;while(left<right){if(nums[left] + nums[right] > nums[i]){sum += (right - left);right--;}else{left++;}}}return sum;}
};

http://www.dtcms.com/wzjs/521234.html

相关文章:

  • 公司网站怎么能被百度收录嘉兴seo外包公司费用
  • 网络工程师app谷歌seo优化中文章
  • 瓦房店 网站建设营销软件代理推广
  • wap企业网站口碑营销成功案例
  • 做app网站的软件叫什么名字吗快排seo软件
  • 网站托管服务网站优化排名金苹果下拉
  • 计算机上网题的模拟网站怎么做凡科网建站系统源码
  • 公司做网站所上传的产品图片seo免费优化软件
  • 好的品牌设计网站有哪些网络优化初学者难吗
  • 政府门户网站建设策划深圳网络推广培训学校
  • 建立企业网站多少钱网络服务公司
  • 网站建设的验收seo营销优化软件
  • 淘宝客 网站建设不完整廊坊seo关键词排名
  • 澄海建网站北京网站sem、seo
  • 珠海建设银行官方网站代运营公司靠谱吗
  • ps制作网站教程医院营销策略的具体方法
  • 网站建设企业有哪些内容今日国际军事新闻头条
  • 网站建设合同首付多少钱游戏推广员平台
  • 天长做网站公司网络营销推广公司简介
  • 虎门做英文网站北京网站优化对策
  • 专业网站的公司网络营销效果评估
  • 高乐雅官方网站 哪个公司做的长春seo顾问
  • 有哪些比较好的企业网站建设万能引流软件
  • 北京网站设计知名乐云seoseo网站优化详解
  • 网站建设请示报告知乎关键词搜索
  • 手机app软件如何制作东莞seo黑帽培训
  • 如何做家具网站最好用的磁力搜索神器
  • 成都科技网站建设电话多少台州seo
  • 楼盘价格哪个网站做的好网络推广怎样做
  • iis如何设置服务器上网站空间大小宁波seo营销平台