最长周长三角形 O(nlogn)
有n根棍子,棍子i的长度为ai。想要从中选出三根棍子组成周长尽可能长的三角形。请输出最大的周长,若无法组成三角形输出0.
思路
很容易想到采用三重循环来枚举所有三角形,复杂度为O(n3)O(n3)成立。这是应该将第n条边排除在外。这样最多排除n-2次,就能知道是否能组成三角形。
实现代码
#include <stdio.h>
#include <algorithm>
using namespace std;
const int maxn = 10000 + 5;
int a[maxn];
int getMAXC(int a[], int n) {
sort(a, a + n);
for(int i = n - 1; i >= 2; i++) {
if(a[i] < a[i - 1] + a[i - 2])
return a[i] + a[i - 1] + a[i - 2];
}
return 0;
}
int main() {
int n;
while(scanf("%d", &n) == 1) {
for(int i = 0; i < n; i++) {
scanf("%d", &a[i]);
}
printf("%d\n", getMAXC(a, n));
}
return 0;
}
如有不当之处欢迎指出!