• UVa 143


      题目大意:果园里的树排列成矩阵,它们的x和y坐标均是1~99的整数。输入若干三角形,依次统计每一个三角形内部和边界上共有多少棵树。

      三角形P0P1P2有向面积为A:2A = x0y1 + x2y0 + x1y2 - x2y1 - x0y2 - x1y0。如果三角形的三个顶点呈逆时针排列,那么有向面积为正,如果是顺时针排列,则有向面积为负。假设输入三角形为ABC,待判断点为O,则O在三角形ABC内部或边界上当且仅当SABC = SOAB + SOBC + SOAC。通过对有向面积取绝对值可以避免三个顶点是否是逆时针的判断,同时要注意计算x、y的最大值和最小值时要限制在[1, 99]的范围内。

     1 #include <cstdio>
     2 #include <cmath>
     3 #include <algorithm>
     4 using namespace std;
     5 #define EPS 1e-9
     6 
     7 double area2(double x0, double y0, double x1, double y1, double x2, double y2)
     8 {
     9     return fabs(x0*y1 + x2*y0 + x1*y2 - x2*y1 - x0*y2 - x1*y0);
    10 }
    11 
    12 int main()
    13 {
    14 #ifdef LOCAL
    15     freopen("in", "r", stdin);
    16 #endif
    17     double x1, x2, x3, y1, y2, y3;
    18     while (scanf("%lf%lf%lf%lf%lf%lf", &x1, &y1, &x2, &y2, &x3, &y3) != EOF)
    19     {
    20         if ((x1 || x2 || x3 || y1 || y2 || y3) == 0)  break;
    21         int x_min = ceil(min(x1, min(x2, x3)));
    22         x_min = max(1, x_min);
    23         int x_max = max(x1, max(x2, x3));
    24         x_max = min(99, x_max);
    25         int y_min = ceil(min(y1, min(y2, y3)));
    26         y_min = max(1, y_min);
    27         int y_max = max(y1, max(y2, y3));
    28         y_max = min(99, y_max);
    29         double S = area2(x1, y1, x2, y2, x3, y3);
    30         int ans = 0;
    31         for (int x = x_min; x <= x_max; x++)
    32             for (int y = y_min; y <= y_max; y++)
    33             {
    34                 double S1 = area2(x1, y1, x2, y2, x, y);
    35                 double S2 = area2(x2, y2, x3, y3, x, y);
    36                 double S3 = area2(x3, y3, x1, y1, x, y);
    37                 if (fabs(S-S1-S2-S3) < EPS)  ans++;
    38             }
    39         printf("%4d
    ", ans);
    40     }
    41     return 0;
    42 }
    View Code

      在取最大值和最小值时,如果min向下取整,max用ceil向上取整,那么考察的范围将会扩大,按理说应该没什么影响,可是那样的话会WA,为什么呢?唉,难懂的浮点数啊...

  • 相关阅读:
    callback的实现
    TypeId和IidManager关系
    Blocks的实现
    定义返回Block的函数
    NSString与奇怪的retainCount
    ARC下的所有权修饰符
    MAC安装MYSQL
    找出数组中只出现一次的数
    写在复习MVC后
    UITableViewHeaderFooterView的封装
  • 原文地址:https://www.cnblogs.com/xiaobaibuhei/p/3280929.html
Copyright © 2020-2023  润新知