UVaOJ 143 Orchard Trees

题目大意:果园里的树排列成矩阵,它们的x和y坐标均是1~99的整数。输入若干三角形,依次统计每一个三角形内部和边界上共有多少棵树。这个题目似乎与高中的解析几何几何有关系,但是若把它当做解析几何来做,就会在无形中增加题目的难度。换个思路,假设三角形ABC,若一个点O在三角形ABC中,则必有S-ABC=S-OAB+S-OAC+S-OBC,变成面积关系即可。
 
 
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);//这里利用了三阶行列式,求出的值是有向三角形面积的2倍
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))); //ceil函数用来返回不小于参数的最小整数
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\n", ans);
40     }
41     return 0;
42 }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值