UVa 143 - Orchard Trees
2013-08-25 16:28
330 查看
题目大意:果园里的树排列成矩阵,它们的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]的范围内。
View Code
在取最大值和最小值时,如果min向下取整,max用ceil向上取整,那么考察的范围将会扩大,按理说应该没什么影响,可是那样的话会WA,为什么呢?唉,难懂的浮点数啊...
三角形P0P1P2有向面积为A:2A = x0y1 + x2y0 + x1y2 - x2y1 - x0y2 - x1y0。如果三角形的三个顶点呈逆时针排列,那么有向面积为正,如果是顺时针排列,则有向面积为负。假设输入三角形为ABC,待判断点为O,则O在三角形ABC内部或边界上当且仅当SABC = SOAB + SOBC + SOAC。通过对有向面积取绝对值可以避免三个顶点是否是逆时针的判断,同时要注意计算x、y的最大值和最小值时要限制在[1, 99]的范围内。
#include <cstdio> #include <cmath> #include <algorithm> using namespace std; #define EPS 1e-9 double area2(double x0, double y0, double x1, double y1, double x2, double y2) { return fabs(x0*y1 + x2*y0 + x1*y2 - x2*y1 - x0*y2 - x1*y0); } int main() { #ifdef LOCAL freopen("in", "r", stdin); #endif double x1, x2, x3, y1, y2, y3; while (scanf("%lf%lf%lf%lf%lf%lf", &x1, &y1, &x2, &y2, &x3, &y3) != EOF) { if ((x1 || x2 || x3 || y1 || y2 || y3) == 0) break; int x_min = ceil(min(x1, min(x2, x3))); x_min = max(1, x_min); int x_max = max(x1, max(x2, x3)); x_max = min(99, x_max); int y_min = ceil(min(y1, min(y2, y3))); y_min = max(1, y_min); int y_max = max(y1, max(y2, y3)); y_max = min(99, y_max); double S = area2(x1, y1, x2, y2, x3, y3); int ans = 0; for (int x = x_min; x <= x_max; x++) for (int y = y_min; y <= y_max; y++) { double S1 = area2(x1, y1, x2, y2, x, y); double S2 = area2(x2, y2, x3, y3, x, y); double S3 = area2(x3, y3, x1, y1, x, y); if (fabs(S-S1-S2-S3) < EPS) ans++; } printf("%4d\n", ans); } return 0; }
View Code
在取最大值和最小值时,如果min向下取整,max用ceil向上取整,那么考察的范围将会扩大,按理说应该没什么影响,可是那样的话会WA,为什么呢?唉,难懂的浮点数啊...
相关文章推荐
- UVA 143 || Orchard Trees (点 P 在三角形内,S(PAB) + S(PAC) + S( PBC) = S(ABC)
- UVA 143 Orchard Trees(判断点在三角形内)
- uva143 - Orchard Trees
- UVa 143 - Orchard Trees
- UVa-143-Orchard Trees(果树林)[计算几何]
- UVa 143 Orchard Trees (数学&计算几何&枚举)
- UVaOJ 143 Orchard Trees
- UVa OJ 143 - Orchard Trees (果树林)
- UVA Orchard Trees(计算几何)
- UVa 10088 - Trees on My Island
- UVa 122 - Trees on the level
- UVA - 122 Trees on the level Map
- 紫书第六章-----数据结构基础(例题6-11 四分树Quadtrees UVA - 297)
- UVA 10303 How Many Trees?
- uva 10562 Undraw the Trees
- UVa 10007 - Count the Trees
- S-Trees UVA - 712
- 算法入门经典习题6-2,uva712,S-Trees
- Uva 712 - S-Trees
- uva 297 Quadtrees