zoukankan      html  css  js  c++  java
  • ACM: Gym 101047K Training with Phuket's larvae

     Gym 101047K Training with Phuket's larvae
    Time Limit:2000MS     Memory Limit:65536KB     64bit IO Format:%I64d & %I64u

    Description

    standard input/output

    Thai cuisine is known for combining seasonings so that every dish has flavors that are sweet (sugar, fruits, bell peppers), spicy, sour (vinegar, tamarind, lime), and salty (soy sauce, fish sauce). The most exotic dish, however, is the one containing fried insect larvae; naturally, it is often showcased to tourists. Westerners usually shudder at the thought of eating larvae, but they are highly valued in Thailand and they are a huge success in parties. Thai children often play with food. They specially like building triangles up using fried larvae as the edges.

    Marcos "the (Rubik) solver" coaches his university's team on a famous computer programming contest. Next year, the contest's world finals will take place in Phuket, Thailand.

    Marcos knows how Thai children like to play with larvae, so he had an idea for a special training session. His idea involves preparing a large amount of fried larvae of several different lengths. Each of his friends, in turn, must select three larvae to build a triangle. Then, the amount of fried larvae each friend has to eat is proportional to the area of the triangle she or he built.

    Marcos hopes that, since you want to eat as little larvae as possible, you'll write a program to choose the larvae that forms a triangle of minimum area. Thus, besides training your computer programming skills, you'll also be training to face Thai cuisine. If you actually enjoy this dish, you may use this program to help your other friends, making sure that there will be more fried larvae left for you.

    Input

    The first line has a single integer T, the number of test cases.

    Each test case starts with an integer N, the number of larvae. In the next line there are N space-separated real numbers a1, ..., an, representing the lengths of the larvae.

    Limits

    • 1 ≤ T ≤ 30
    • 1 ≤ N ≤ 2·103
    • 1 ≤ ai ≤ 500
    • The sum of N over all test cases will not exceed 6·103

    Output

    For each test case, print a single line containing the minimum area for that case, the error should not exceed 10 - 4; if it is not possible to build a triangle from the larvae, print -1.

    Sample Input

    Input
    3
    4
    3 4 5 6
    3
    1 2 4
    5
    3.4 2.8 7.1 5.2 10
    Output
    5.3326822519
    -1
    4.3599885321

    /*/
    题意:
    给你n条边,问这n条边构成的三角形的面积最小是多少。
    
    题意很简单,想着暴力,一看复杂度 O(8*n^3) ...  让我冷静下。。
    
    然后想到枚举两条边用二分第三条边~TLE 噗。。
    
    后面考虑了很久,要求最小的面积,只有三角形是那种细长细长的才能最小,又枚举 i 和 j 是按照顺序来枚举的,只要找到,比 i+j 小一点点的的就行了。
    
    用到lower_bound( , , );函数;
    
    AC代码:
    /*/

    #include <map>
    #include <set>
    #include <cmath>
    #include <ctime>
    #include <stack>
    #include <queue>
    #include <cstdio>
    #include <cctype>
    #include <bitset>
    #include <string>
    #include <vector>
    #include <cstring>
    #include <iostream>
    #include <algorithm>
    #include <functional>
    #define debug(x) cout<<"["<<x<<"]";
    #define FIN freopen("input.txt","r",stdin);
    #define FOUT freopen("output.txt","w+",stdout);
    //#pragma comment(linker, "/STACK:102400000,102400000")
    using namespace std;
    typedef long long LL;
    typedef pair<int, int> PII;
    const int MAX=1e5+5;
    
    
    double Check(double a,double b,double c) {
    	double s;
    	double p=(a+b+c)/2;
    	return s=sqrt((p-a)*(p-b)*(p-c)*p);
    }
    
    int main() {
    	int T;
    	double a[MAX];
    	cin>>T;
    	while(T--) {
    		int n;
    		scanf("%d",&n);
    		for(int i=0; i<n; i++) {
    			scanf("%lf",&a[i]);
    		}
    		double ans=1e9+10000;
    		sort(a,a+n);
    		for(int i=0; i<n; i++) {
    			for(int j=i+1; j<n-1; j++) {
    				if(a[i]+a[j]>a[j+1]) ans=min(ans,Check(a[i],a[j],a[j+1]));
    				int k=lower_bound(a+j,a+n,a[i]+a[j])-a-1;
    				if(k>j&&a[k]<a[i]+a[j]) ans=min(ans,Check(a[i],a[j],a[k]));
    			}
    		}
    		if(ans!=1e9+10000)
    			printf("%.10lf
    ",ans);
    		else
    			printf("-1
    ");
    	}
    	return 0;
    }
    
    
    

      

     


  • 相关阅读:
    PHP date 格式化一个本地时间/日期
    Unix时间戳(Unix timestamp)转换工具
    Ubuntu下搭建NodeJS+Express WEB开发框架
    高手指南PHP安装配置
    thinkphp系统常量与自定义常量
    UDP 构建p2p打洞过程的实现原理(持续更新)
    iOS标准时间与时间戳相互转换
    java 时间戳和PHP时间戳 的转换
    Windows与Linux/Mac系统时间不一致的解决方法
    推荐25款php中非常有用的类库
  • 原文地址:https://www.cnblogs.com/HDMaxfun/p/5797020.html
Copyright © 2011-2022 走看看