Raymond&yin 2020-02-23 14:51 采纳率: 0%
浏览 449

hdu的1558题,为何这样写代码,会memory limit exceed

#include<stdio.h>
#include<cmath>
using namespace std;

struct Point {
    double x, y;
    Point(double X = 0, double Y = 0) { x = X, y = Y; }
    Point operator + (Point B) { return Point(x + B.x, y + B.y); }
    Point operator - (Point B) { return Point(x - B.x, y - B.y); }
    Point operator * (double k) { return Point(x*k, y*k); }
    Point operator / (double k) { return Point(x / k, y / k); }
};
struct Line {
    Point p1, p2;
    Line() {}
    Line(Point P1, Point P2) { p1 = P1; p2 = P2; }
};

typedef Point Vector;

const double eps = 1e-8;
Line line[100];
int pre[100];

int sgn(double a) {
    if (fabs(a) < eps)
        return 0;
    else
        return a < 0 ? -1 : 1;
}

double Cross(Vector A, Vector B) { return B.y*A.x - B.x*A.y; }

bool Cross_segment(Point a, Point b, Point c, Point d) {    //判断两线段是否相交
    double c1 = Cross(b - a, c - a), c2 = Cross(b - a, d - a);
    double d1 = Cross(d - c, a - c), d2 = Cross(d - c, b - c);
    return sgn(c1)*sgn(c2) < 0 && sgn(d1)*sgn(d2) < 0;  //1相交 0不相交 
}

int find(int u) {       //并查集搜索
    return pre[u] == u ? u : pre[u] = find(pre[u]);
}

int main() {
    int ccase;
    scanf("%d", &ccase);
    while (ccase--) {
        for (int i = 0; i < 100; i++)
            pre[i] = i;

        int k = 1;  //线段数 
        char t;
        int n;
        scanf("%d", &n);        //指令数 
        while (n--) {
            t = getchar();
            while (t == ' ' || t == '\n')
                t = getchar();
            if (t == 'P') {
                scanf("%lf%lf%lf%lf", &line[k].p1.x, &line[k].p1.y, &line[k].p2.x, &line[k].p2.y);
                k++;
                for (int i = 1; i < k - 1; i++) {
                    if (Cross_segment(line[k - 1].p1, line[k - 1].p2, line[i].p1, line[i].p2)) {        //如果两线段相交
                        int x = pre[k - 1];
                        int y = pre[i];
                        if (x != y)
                            pre[x] = y;
                    }
                }
            }
            else {
                int x;
                int num = 0;
                scanf("%d", &x);
                x = find(x);
                for (int i = 1; i < k; i++)
                    if (find(i) == x)
                        num++;
                printf("%d\n", num);
            }

        }
        printf("\n");
    }

    return 0;
}
  • 写回答

1条回答 默认 最新

  • threenewbee 2020-02-23 15:09
    关注

    int find(int u) { //并查集搜索
    return pre[u] == u ? u : pre[u] = find(pre[u]);
    }
    是不是这里无限递归了

    评论

报告相同问题?

悬赏问题

  • ¥20 基于MSP430f5529的MPU6050驱动,求出欧拉角
  • ¥20 Java-Oj-桌布的计算
  • ¥15 powerbuilder中的datawindow数据整合到新的DataWindow
  • ¥20 有人知道这种图怎么画吗?
  • ¥15 pyqt6如何引用qrc文件加载里面的的资源
  • ¥15 安卓JNI项目使用lua上的问题
  • ¥20 RL+GNN解决人员排班问题时梯度消失
  • ¥60 要数控稳压电源测试数据
  • ¥15 能帮我写下这个编程吗
  • ¥15 ikuai客户端l2tp协议链接报终止15信号和无法将p.p.p6转换为我的l2tp线路