Valid Triangle Number问题及解法
2017-09-27 12:02
375 查看
问题描述:
Given an array consists of non-negative integers, your task is to count the number of triplets chosen from the array that can make triangles if we take them as side lengths of a triangle.
示例:
问题分析:
先把数组升序排序,依次取一个值nums[i]作为三角形的一个最长边。那么我们就可以在[0.i-1]的范围内寻找满足当前条件的三角形个数。由于数组数升序排列的,我们只需要找到两条边的一个边界即可,例如两边分别为a和b(a<b,a+b > nums[i]),比a小的边与b的和小于nums[i]。因而以b作为次长边的三角形个数为b的索引- a的索引。不断改变a和b求解即可。
过程详见代码:
class Solution {
public:
int triangleNumber(vector<int>& nums) {
int res = 0;
sort(nums.begin(), nums.end());
for (int i = 0; i<nums.size(); i++)
{
int left = 0, right = i - 1;
while (left<right)
{
if (nums[right] + nums[left]>nums[i])
{
res += right - left;
right--;
}
else
{
left++;
}
}
}
return res;
}
};
Given an array consists of non-negative integers, your task is to count the number of triplets chosen from the array that can make triangles if we take them as side lengths of a triangle.
示例:
Input: [2,2,3,4] Output: 3 Explanation: Valid combinations are: 2,3,4 (using the first 2) 2,3,4 (using the second 2) 2,2,3
问题分析:
先把数组升序排序,依次取一个值nums[i]作为三角形的一个最长边。那么我们就可以在[0.i-1]的范围内寻找满足当前条件的三角形个数。由于数组数升序排列的,我们只需要找到两条边的一个边界即可,例如两边分别为a和b(a<b,a+b > nums[i]),比a小的边与b的和小于nums[i]。因而以b作为次长边的三角形个数为b的索引- a的索引。不断改变a和b求解即可。
过程详见代码:
class Solution {
public:
int triangleNumber(vector<int>& nums) {
int res = 0;
sort(nums.begin(), nums.end());
for (int i = 0; i<nums.size(); i++)
{
int left = 0, right = i - 1;
while (left<right)
{
if (nums[right] + nums[left]>nums[i])
{
res += right - left;
right--;
}
else
{
left++;
}
}
}
return res;
}
};
相关文章推荐
- Leetcode之Valid Triangle Number 问题
- Pascal's Triangle II问题及解法
- Guess Number Higher or Lower问题及解法
- Triangle问题及解法
- Pascal's Triangle问题及解法
- Single Number III问题及解法
- Valid Perfect Square问题及解法
- Number of Boomerangs问题及解法
- Array-Valid Triangle Number
- Find the Duplicate Number问题及解法
- LeetCode Valid Triangle Number
- Guess Number Higher or Lower II问题及解法
- Excel Sheet Column Number问题及解法
- LeetCode Single Number I & II 都符合两个问题额外要求的 通用解法 与 思考过程
- Valid Triangle Number (第十六周 数组)
- Leetcode算法学习日志-611 Valid Triangle Number
- Minimum Number of Arrows to Burst Balloons问题及解法
- Third Maximum Number问题及解法
- Leetcode: Valid Number的三种解法
- [LeetCode] Valid Triangle Number 合法的三角形个数