博客
关于我
FZU 1015 土地划分
阅读量:157 次
发布时间:2019-02-27

本文共 1902 字,大约阅读时间需要 6 分钟。

为了解决这个问题,我们需要计算农庄主划分土地后的块数。农庄主使用矩形地图划分线段,每条线段从一条边界的点到另一条边界的点。我们的任务是计算这些线段划分后的区域数量。

方法思路

  • 问题分析:每条线段连接矩形边界的两个点,可能会与其他线段相交,导致区域数量增加。我们需要计算所有线段之间的交点数目,从而确定最终的区域数量。
  • 交点计算:使用行列式方法判断两条线段是否相交,并确定交点是否在线段内部。这样可以确保我们只计算有效的交点。
  • 区域计算:初始区域数为1,每条线段增加1个区域。每次两条线段相交,区域数增加1个。总的区域数等于1 + 线段数 + 交点数。
  • 解决代码

    #include 
    using namespace std;struct Point { int x; int y;};bool is_intersect(const Point& a, const Point& b, const Point& c, const Point& d) { int dx1 = b.x - a.x; int dy1 = b.y - a.y; int dx2 = d.x - c.x; int dy2 = d.y - c.y; int D = dx1 * dy2 - dx2 * dy1; if (D == 0) { return false; } int numerator_t = (c.x - a.x) * dy2 - (d.x - c.x) * (c.y - a.y); float t = static_cast
    (numerator_t) / D; int numerator_s = dx1 * (c.y - a.y) - dx2 * (b.y - a.y); float s = static_cast
    (numerator_s) / D; return (t >= 0 && t <= 1) && (s >= 0 && s <= 1);}int main() { int w, h; Point** lines = new Point*; while (true) { cin >> w >> h; if (w == 0 && h == 0) { break; } int L = 0; cin >> L; lines = new Point*[L + 1]; for (int i = 1; i <= L; ++i) { int x, y; cin >> x >> y; lines[i] = new Point(x, y); } int count = 0; for (int i = 1; i <= L; ++i) { Point a = lines[i][0]; Point b = lines[i][1]; for (int j = 1; j < i; ++j) { Point c = lines[j][0]; Point d = lines[j][1]; if (is_intersect(a, b, c, d)) { count++; } } } int regions = 1 + L + count; cout << regions << endl; } delete[] lines; return 0;}

    代码解释

  • 结构体Point:用于存储坐标点。
  • is_intersect函数:判断两条线段是否相交,并返回交点是否在线段内部。
  • 主函数:读取输入数据,处理每组数据,计算交点数目,并输出区域数量。对于每条线段,检查它与之前所有线段的交点,累加交点数目,最后计算总区域数。
  • 该方法通过计算线段的交点数目,准确地确定了区域数量,确保了结果的正确性。

    转载地址:http://fcid.baihongyu.com/

    你可能感兴趣的文章
    operator new 与 operator delete
    查看>>
    operator() error
    查看>>
    OPPO K3在哪里打开USB调试模式的完美方法
    查看>>
    oppo后端16连问
    查看>>
    OPPO软件商店APP侵权投诉流程
    查看>>
    Optional类:避免NullPointerException
    查看>>
    Optional讲解
    查看>>
    ORA-00923: 未找到要求的 FROM 关键字
    查看>>
    ORA-00932: inconsistent datatypes: expected - got NCLOB【ORA-00932: 数据类型不一致: 应为 -, 但却获得 NCLOB 】【解决办法】
    查看>>
    ORA-00942 表或视图不存在
    查看>>
    ORA-01034: ORACLE not available
    查看>>
    ORA-01152: 文件 1 没有从过旧的备份中还原
    查看>>
    ORA-01207:文件比控制文件更新 - 旧的控制文件
    查看>>
    ORA-01795: 列表中的最大表达式数为 1000
    查看>>
    ORA-06575: 程序包或函数 NO_VM_DROP_PROC 处于无效状态
    查看>>
    ORA-08102的错误
    查看>>
    ORA-12505, TNS:listener does not currently know of SID given in connect descriptor异常
    查看>>
    ORA-12514: TNS:listener does not currently know of service问题原因
    查看>>
    ora-12541:tns:no listener
    查看>>
    【docker知识】联合文件系统(unionFS)原理
    查看>>