UVALive - 7428(三维计算几何)

暴力。求飞行距离以及在海上飞的距离占总距离的百分比。
对于圆心在原点的球,求两个圆弧的交点。可以先弄出两个圆弧所在的平面的法向量,做叉积,求出来的就是两个平面相交的直线的方向向量。因为球面上两个圆弧所在平面相交,交的直线肯定是经过原点的直径所在的直线,所以直径化成单位向量R,就是交点。
z判断交点p在不在圆弧(p1, p2)上,只需要满足 dis(p, p1) + dis(p, p2) == dis(p1, p2)

#include <bits/stdc++.h>

using namespace std;


#define N 100010
#define M 1000010
#define ULL unsigned long long
#define LL long long
#define ls (i << 1)
#define rs (ls | 1)
#define md ((ll + rr) >> 1)
#define lson ll, md, ls
#define rson md + 1, rr, rs
#define inf 0x3f3f3f3f
#define eps 1e-10
#define pii pair<int, int>
#define MP make_pair
#define mod 1000000007
#define sqr(x) ((x) * (x))
#define Pi acos(-1.0)

double dcmp(double x){
    if(fabs(x) < eps) return 0;
    return x < 0 ? -1 : 1;
}
struct point{
    double x, y, z;
    point(double x = 0, double y = 0, double z = 0) : x(x), y(y), z(z) {}
    point operator - (const point &b) const {
        return point(x - b.x, y - b.y, z - b.z);
    }
    point operator * (const double &k) const {
        return point(x * k, y * k, z * k);
    }
    double len(){
        return sqrt(x * x + y * y + z * z);
    }
    point fix(){
        double l = len();
        return point(x / l, y / l, z / l);
    }
};
double torad(double deg){
    return deg / 180 * Pi;
}
point get_coord(double lat, double lng, double r){
    point ret;
    lat = torad(lat), lng = torad(lng);
    ret.x = r * cos(lat) * cos(lng);
    ret.y = r * cos(lat) * sin(lng);
    ret.z = r * sin(lat);
    return ret;
}
point cross(point a, point b){
    return point(a.y * b.z - a.z * b.y, a.z * b.x - a.x * b.z, a.x * b.y - a.y * b.x);
}
double calc(point a, point b, double R){
    double d = (a - b).len();
    return 2 * R * asin(d / (2 * R));
}
const double R = 6370.0;
bool check(point p1, point p2, point p){
    double len1 = calc(p1, p, R);
    double len2 = calc(p2, p, R);
    double len = calc(p1, p2, R);
    return dcmp(len - len1 - len2) == 0;
}
bool inter(point p1, point p2, point q1, point q2, point &res){
    point n1 = cross(p1, p2);
    point n2 = cross(q1, q2);
    point v1 = cross(n1, n2), v2 = point(0, 0, 0) - v1;
    v1 = v1.fix() * R, v2 = v2.fix() * R;
    if(check(p1, p2, v1) && check(q1, q2, v1)){ res = v1; return 1; }
    if(check(p1, p2, v2) && check(q1, q2, v2)){ res = v2; return 1; }
    return 0;
}

point p[33][33], pp[33], fp[133];
point o;
int sz[N];
bool cmp(point a, point b){
    return calc(a, o, R) < calc(b, o, R);
}
int main(){
    int n, m;
    while(scanf("%d", &n) != EOF){
        for(int i = 0; i < n; ++i){
            scanf("%d", &sz[i]);
            for(int j = 0; j < sz[i]; ++j){
                double x, y;
                scanf("%lf%lf", &x, &y);
                p[i][j] = get_coord(x, y, R);
            }
            p[i][sz[i]] = p[i][0];
        }
        double ans = 0, sea = 0;
        bool f = 0;
        scanf("%d", &m);
        for(int i = 0; i < m; ++i){
            double x, y;
            scanf("%lf%lf", &x, &y);
            pp[i] = get_coord(x, y, R);
        }
        for(int i = 1; i < m; ++i){
            ans += calc(pp[i], pp[i-1], R);
            int cnt = 0;
            for(int j = 0; j < n; ++j){
                for(int k = 0; k < sz[j]; ++k){
                    point res;
                    if(inter(pp[i], pp[i-1], p[j][k], p[j][k+1], res))
                        fp[cnt++] = res;
                }
            }
            fp[cnt++] = pp[i];
            fp[cnt++] = pp[i-1];
            o = pp[i-1];
            sort(fp, fp + cnt, cmp);
            cout << cnt << endl;
            for(int i = 1; i < cnt; i += 2){
                if(f) sea += calc(fp[i], fp[i-1], R);
                else if(i + 1 < cnt) 
                    sea += calc(fp[i+1], fp[i], R);
                else ;
            }
            if(cnt % 2) f ^= 1;
        }   
        printf("%.9f %.9f\n", ans, sea * 100 / ans);
    }
    return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
东南亚位于我国倡导推进的“一带一路”海陆交汇地带,作为当今全球发展最为迅速的地区之一,近年来区域内生产总值实现了显著且稳定的增长。根据东盟主要经济体公布的最新数据,印度尼西亚2023年国内生产总值(GDP)增长5.05%;越南2023年经济增长5.05%;马来西亚2023年经济增速为3.7%;泰国2023年经济增长1.9%;新加坡2023年经济增长1.1%;柬埔寨2023年经济增速预计为5.6%。 东盟国家在“一带一路”沿线国家中的总体GDP经济规模、贸易总额与国外直接投资均为最大,因此有着举足轻重的地位和作用。当前,东盟与中国已互相成为双方最大的交易伙伴。中国-东盟贸易总额已从2013年的443亿元增长至 2023年合计超逾6.4万亿元,占中国外贸总值的15.4%。在过去20余年中,东盟国家不断在全球多变的格局里面临挑战并寻求机遇。2023东盟国家主要经济体受到国内消费、国外投资、货币政策、旅游业复苏、和大宗商品出口价企稳等方面的提振,经济显现出稳步增长态势和强韧性的潜能。 本调研报告旨在深度挖掘东南亚市场的增长潜力与发展机会,分析东南亚市场竞争态势、销售模式、客户偏好、整体市场营商环境,为国内企业出海开展业务提供客观参考意见。 本文核心内容: 市场空间:全球行业市场空间、东南亚市场发展空间。 竞争态势:全球份额,东南亚市场企业份额。 销售模式:东南亚市场销售模式、本地代理商 客户情况:东南亚本地客户及偏好分析 营商环境:东南亚营商环境分析 本文纳入的企业包括国外及印尼本土企业,以及相关上下游企业等,部分名单 QYResearch是全球知名的大型咨询公司,行业涵盖各高科技行业产业链细分市场,横跨如半导体产业链(半导体设备及零部件、半导体材料、集成电路、制造、封测、分立器件、传感器、光电器件)、光伏产业链(设备、硅料/硅片、电池片、组件、辅料支架、逆变器、电站终端)、新能源汽车产业链(动力电池及材料、电驱电控、汽车半导体/电子、整车、充电桩)、通信产业链(通信系统设备、终端设备、电子元器件、射频前端、光模块、4G/5G/6G、宽带、IoT、数字经济、AI)、先进材料产业链(金属材料、高分子材料、陶瓷材料、纳米材料等)、机械制造产业链(数控机床、工程机械、电气机械、3C自动化、工业机器人、激光、工控、无人机)、食品药品、医疗器械、农业等。邮箱:market@qyresearch.com

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值