题目链接:Save Labman No.004

解题思路:给你两条直线,异面的空间直线,求直线间最短距离,并且求出最短距离的这两个点。下面是模板,先求出公垂线的法向量,在构造两个平面分别是两条直线各自跟公垂线的平面,会与另一条直线有交点,这两个交点就是所求的点。

#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <algorithm>
#include <cmath>using namespace std;const double EPS = 1e-9;
const int MAXN = 40;struct Point3  //空间点
{double x, y, z;Point3( double x=0, double y=0, double z=0 ): x(x), y(y), z(z) { }Point3( const Point3& a ){x = a.x;y = a.y;z = a.z;return;}void showP(){printf("%f %f %f \n", x, y, z);}Point3 operator+( Point3& rhs ){return Point3( x+rhs.x, y+rhs.y, z+rhs.z );}
};struct Line3   //空间直线
{Point3 a, b;Line3 (){}Line3 (Point3 x, Point3 y){a = x, b = y;}
};struct plane3   //空间平面
{Point3 a, b, c;plane3() {}plane3( Point3 a, Point3 b, Point3 c ):a(a), b(b), c(c) { }void showPlane(){a.showP();b.showP();c.showP();return;}
};double dcmp( double a )
{if ( fabs( a ) < EPS ) return 0;return a < 0 ? -1 : 1;
}//三维叉积
Point3 Cross3( Point3 u, Point3 v )
{Point3 ret;ret.x = u.y * v.z - v.y * u.z;ret.y = u.z * v.x - u.x * v.z;ret.z = u.x * v.y - u.y * v.x;return ret;
}//三维点积
double Dot3( Point3 u, Point3 v )
{return u.x * v.x + u.y * v.y + u.z * v.z;
}//矢量差
Point3 Subt( Point3 u, Point3 v )
{Point3 ret;ret.x = u.x - v.x;ret.y = u.y - v.y;ret.z = u.z - v.z;return ret;
}//两点距离
double TwoPointDistance( Point3 p1, Point3 p2 )
{return sqrt( (p1.x - p2.x)*(p1.x - p2.x) + (p1.y - p2.y)*(p1.y - p2.y) + (p1.z - p2.z)*(p1.z - p2.z) );
}//向量的模
double VectorLenth( Point3 p )
{return sqrt( p.x*p.x + p.y*p.y + p.z*p.z );
}//空间直线距离
double LineToLine( Line3 u, Line3 v, Point3& tmp )
{tmp = Cross3( Subt( u.a, u.b ), Subt( v.a, v.b ) );return fabs( Dot3( Subt(u.a, v.a), tmp ) ) / VectorLenth(tmp);
}//取平面法向量
Point3 pvec( plane3 s )
{return Cross3( Subt( s.a, s.b ), Subt( s.b, s.c ) );
}//空间平面与直线的交点
Point3 Intersection( Line3 l, plane3 s )
{Point3 ret = pvec(s);double t = ( ret.x*(s.a.x-l.a.x)+ret.y*(s.a.y-l.a.y)+ret.z*(s.a.z-l.a.z) )/( ret.x*(l.b.x-l.a.x)+ret.y*(l.b.y-l.a.y)+ret.z*(l.b.z-l.a.z) );ret.x = l.a.x + ( l.b.x - l.a.x ) * t;ret.y = l.a.y + ( l.b.y - l.a.y ) * t;ret.z = l.a.z + ( l.b.z - l.a.z ) * t;return ret;
}int main(){int t;Point3 a, b, c, d, tem;Point3 u, v, n;plane3 o, p;scanf("%d", &t);while(t--){scanf("%lf%lf%lf%lf%lf%lf%lf%lf%lf%lf%lf%lf", &a.x, &a.y, &a.z, &b.x, &b.y, &b.z, &c.x, &c.y, &c.z, &d.x, &d.y, &d.z);double dis = LineToLine(Line3(a, b), Line3(c, d), tem);printf("%lf\n", dis);u = Subt(a, b), v = Subt(c, d);n = Cross3(u, v);o = plane3(a, b, Point3(a.x + n.x, a.y + n.y, a.z + n.z));p = plane3(c, d, Point3(c.x + n.x, c.y + n.y, c.z + n.z));u = Intersection(Line3(a, b), p);v = Intersection(Line3(c, d), o);printf("%.6lf %.6lf %.6lf %.6lf %.6lf %.6lf\n", u.x, u.y, u.z, v.x, v.y, v.z);}return 0;
}

POJ 4741 Save Labman No.004相关推荐

  1. hdu 4741 Save Labman No.004

    题目大意:求空间两条直线的最短距离及最近的点坐标 题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4741 拙计的代码,公垂线~~~~~~~~~ #inc ...

  2. HDU 4741 Save Labman No.004 计算几何 数学

    题目链接 这道题会暴露很多孩纸的高数学的好不好.如何计算三维直线的最短距离和垂足的坐标,学习链接 之后的就是代入公式计算了. 1 #include <stdio.h> 2 #include ...

  3. HDU 4741 Save Labman No.004(计算几何)

    题目链接 抄的模版...mark一下. 1 #include <iostream> 2 #include <cstring> 3 #include <cstdio> ...

  4. [HDU 4741]Save Labman No.004[计算几何][精度]

    题意: 求两条空间直线的距离,以及对应那条距离线段的两端点坐标. 思路: 有一个参数方程算最短距离的公式, 代入求即可. 但是这题卡精度... 用另外的公式(先算出a直线上到b最近的点p的坐标, 再算 ...

  5. 2013_hangzhou_online

    4738 Caocao's Bridges 求无向图的桥中最小的那个,tarjan 4739 Zhuge Liang's Mines 状态压缩+暴力 4740 The Donkey of Gui Zh ...

  6. 三元一次方程组计算机解法,math 三元一次方程组的解法

    math & 三元一次方程组的解法 class 6 math 例题 问题: 1. 已经做好的与没有做好的比例是 5 比 7; 2 再做好51,完成总数的 70%; 3. 问,一共要做多少朵花? ...

  7. docker Gitlab14.5.0 初始化账号以及密码是什么呢?

    文章目录 1. 进入容器 2. 进入bin目录 3. 执行命令 4. 执行命令 5. 修改密码 6. 确认密码 7. 保存修改 8. 操作记录(全) 9. 操作截图(全) 这时,gitlab已经跑起来 ...

  8. 【POJ - 1364】King(差分约束判无解)

    题干: Once, in one kingdom, there was a queen and that queen was expecting a baby. The queen prayed: ` ...

  9. Black Box(POJ 1442·TREAP实现)

    传送门:http://poj.org/problem?id=1442 Black Box Time Limit: 1000MS   Memory Limit: 10000K       Descrip ...

最新文章

  1. share extension 不显示_你所不知道的网红小酒馆Helens
  2. PacBio But Not Illumina Technology Can Achieve Fast, Accurate and Complete Closure of the High GC, C
  3. SP 2010: Getting started with Business Connectivity Services (BCS) in SharePoint 2010
  4. 可能是目前轻量级弹幕控件中功能最强大的一款
  5. javadoc文档的生成方法_Cocoa 代码注释与文档生成
  6. 互联网连菜市场也不放过
  7. 单片机应用中的c语言用词注解,嵌入式C编程 PIC单片机和C编程技术与应用pdf
  8. 不同Ubuntu版本,对应ROS版本
  9. 喜报!字根科技牵手荣之联,提供错别字检测解决方案
  10. 【d3】树图-各种效果集合(附效果图)
  11. OSChina 周二乱弹 ——室友开始买假发女装了
  12. C++ fabs和abs区别
  13. 力扣(LeetCode)刷题笔记
  14. 一文详解目前最火的多传感器融合技术
  15. 怎样查看Eclipse是32位还是64位
  16. MATLAB数学经典建模之风扇特性:流量 随 压比函数值变化的图形 (2 维图形)
  17. 正点原子的内存管理_LWIP操作系统实操讲解-正点原子手把手教你学系列
  18. 4.4V/3.85V锂电池充电器方案
  19. 【爱贝云计费】支付接入流程
  20. Android最火的开源项目

热门文章

  1. 夜深人静学32系列16——RTC实时时钟
  2. 联想 Yoga C740::关于Ubuntu16.04下无法识别Intel WIFI6 AX201无线网卡的解决方案
  3. 常用注解,依赖,常用类,插件和其它(自用)
  4. win10系统IIS服务器配置详细教程,小编为你细说win10系统配置iis的详细
  5. 2020赛季-王者荣耀英雄分析
  6. python正则表达式两个条件_python高级正则表达式
  7. 2015年广东省广州市各类型POI
  8. 【阿里云】ECS 使用 Ossfs 挂载 OSS 存储
  9. 尼姆游戏(人机对战)的Python实现
  10. 透过8个行业,带你了解Web 3.0区块链网络时代的颠覆性,你的行业会被颠覆吗?...