求全部点组成的三角形最小的面积,0除外。

本题就枚举全部能够组成的三角形,然后保存最小的就是答案了。由于数据量非常少。

复习一下怎样求三角形面积。最简便的方法就是向量叉乘的知识了。

并且是二维向量叉乘P1(ax, ay), P2(bx, by)。公式为:|P1 X P2| = abs(ax*by - ay*bx)

三角形面积就是|P1 X P2| / 2;

本题也是float过不了。换成double就能够过了。

  1. const int MAX_N = 101;
  2. struct VertexPoint
  3. {
  4. double x, y;
  5. float crossProduct(const VertexPoint &n) const
  6. {
  7. return x * n.y - y * n.x; //cross product
  8. }
  9. VertexPoint operator-(const VertexPoint &n) const
  10. {
  11. VertexPoint a;
  12. a.x = x - n.x;
  13. a.y = y - n.y;
  14. return a;
  15. }
  16. };
  17.  
  18. int N;
  19. VertexPoint P[MAX_N];
  20.  
  21. int main()
  22. {
  23. int T;
  24. VertexPoint a, b;
  25. scanf("%d", &T);
  26. while (T--)
  27. {
  28. scanf("%d", &N);
  29. for (int i = 0; i < N; i++)
  30. {
  31. scanf("%lf %lf", &P[i].x, &P[i].y);
  32. }
  33. double area = DBL_MAX;
  34. for (int i = 0; i < N; i++)
  35. {
  36. for (int j = i+1; j < N; j++)
  37. {
  38. for (int k = j+1; k < N; k++)
  39. {
  40. a = P[j] - P[i];
  41. b = P[k] - P[i];
  42. double tmp = fabs(a.crossProduct(b) * 0.5);
  43. if (tmp > DBL_EPSILON) area = min(area, tmp);
  44. }
  45. }
  46. }
  47. if (area == DBL_MAX) puts("Impossible");
  48. else printf("%.2lf\n", area);
  49. }
  50. return 0;
  51. }

HDU 4709 Herding 几何题解的更多相关文章

  1. hdu 4709:Herding(叉积求三角形面积+枚举)

    Herding Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Sub ...

  2. hdu - 4709 - Herding

    题意:给出N个点的坐标,从中取些点来组成一个多边形,求这个多边形的最小面积,组不成多边形的输出"Impossible"(测试组数 T <= 25, 1 <= N < ...

  3. HDU 4709 Herding (枚举)

    Herding Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Sub ...

  4. hdu 4709 Herding hdu 2013 热身赛

    题意:给出笛卡尔坐标系上 n 个点,n不大于100,求出这些点中能围出的最小面积. 可以肯定的是三个点围成的面积是最小的,然后就暴力枚举,计算任意三点围成的面积.刚开始是求出三边的长,然后求面积,运算 ...

  5. 学习数论 HDU 4709

    经过杭师大校赛的打击,明白了数学知识的重要性 开始学习数论,开始找题练手 Herding HDU - 4709 Little John is herding his father's cattles. ...

  6. HDU 4709:Herding

    Herding Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Su ...

  7. 【Herding HDU - 4709 】【数学(利用叉乘计算三角形面积)】

    题意:给出n个点的坐标,问取出其中任意点围成的区域的最小值! 很明显,找到一个合适的三角形即可. #include<iostream> #include<cstdio> #in ...

  8. HDU 4709 3-idiots FFT 多项式

    http://acm.hdu.edu.cn/showproblem.php?pid=4609 给一堆边,求这一堆边随便挑三个能组成三角形的概率. 裸fft,被垃圾题解坑了还以为很难. 最长的边的长度小 ...

  9. hdu 5839(三维几何)

    Special Tetrahedron Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Othe ...

随机推荐

  1. C++拷贝构造函数详解

    转自:http://blog.csdn.net/lwbeyond/article/details/6202256 对于一个空类,编译器默认生成四个成员函数:默认构造函数.析构函数.拷贝构造函数.赋值函 ...

  2. 域用户允许更改IP地址

    1.在DC上设置不好使. 2.需在本地用户组里添加到network.......组里. 注意:有的时候,连接不到DC上,是由于DNS的事,需要先去掉不必要的dns地址. 添加完后,需要重启或注销. 另 ...

  3. ios8.1上运行程序,程序界面只显示一部分

    在ios 9.1上运行程序没问题 但是在8.1上运行发现模拟器上只显示了程序的一小部分界面,没有显示完全. 结果发现由以下代码设置问题引起的 - (BOOL)application:(UIApplic ...

  4. javascript复制

    1.实现点击按钮,复制文本框中的的内容 1 <scrip type="text/javascript"> 2 function copyUrl2() 3 { 4 var ...

  5. Java--finally

    finally 子句(clause)是不是总会执行??? package com.volshell.test; public class Main { public static void main( ...

  6. HDU 5012 Dice DFS

    简单DFS //#pragma comment(linker, "/STACK:16777216") //for c++ Compiler #include <stdio.h ...

  7. 为centos添加第三方源

    默认centos自带的源少了很多好软件,所以需要添加第三方源一.安装CentOS yum源优先级插件yum-prioritiesyum install yum-plugin-priorities.no ...

  8. JDK1.6官方下载

    JDK1.6官方下载_JDK6官方下载地址:http://www.java.net/download/jdk6/6u10/promoted/b32/binaries/jdk-6u10-rc2-bin- ...

  9. 算法之旅,直奔<algorithm>之十 count_if

    count_if(vs2010) 引言 这是我学习总结<algorithm>的第十篇,这个重要的地方是设置条件.用的还是蛮多的.(今天下午挺恶心的,一下午就做一个面试题,调代码调傻了... ...

  10. 【转】文件恢复神器extundelete

    参考博文: 1.Linux中VMware虚拟机增加磁盘空间的扩容操作 http://www.net130.com/CMS/Pub/special/special_virtual/special_vir ...