博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
51nod 1265 四点共面【计算几何+线性代数】
阅读量:7221 次
发布时间:2019-06-29

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

基准时间限制:1 秒 空间限制:131072 KB 分值: 0 
 收藏
 关注
给出三维空间上的四个点(点与点的位置均不相同),判断这4个点是否在同一个平面内(4点共线也算共面)。如果共面,输出"Yes",否则输出"No"。
Input
第1行:一个数T,表示输入的测试数量(1 <= T <= 1000)第2 - 4T + 1行:每行4行表示一组数据,每行3个数,x, y, z, 表示该点的位置坐标(-1000 <= x, y, z <= 1000)。
Output
输出共T行,如果共面输出"Yes",否则输出"No"。
Input示例
11 2 02 3 04 0 00 0 0
Output示例
Yes

【分析】:由四个点创建三个向量,构成一个行列式,若行列式值为0,共面 ——> 线性代数的3个向量线性相关的行列式为0.

3阶行列式的计算方法。\det(X,X ',X '')=\begin{vmatrix} x & x' &x''\\ y & y'&y''\\ z&z'&z'' \end{vmatrix}=xy'z''+x'y''z+x''yz'-xy''z'-x'yz''-x''y'z

【代码】:

#include 
#include
#include
#include
#include
using namespace std;struct node{ int x,y,z;}a[1005];int main(){ int t; node s1,s2,s3; scanf("%d",&t); while(t--) { for(int i=1;i<=4;i++) { scanf("%d%d%d",&a[i].x,&a[i].y,&a[i].z); } s1.x=a[2].x-a[1].x; s1.y=a[2].y-a[1].y; s1.z=a[2].z-a[1].z; s2.x=a[3].x-a[1].x; s2.y=a[3].y-a[1].y; s2.z=a[3].z-a[1].z; s3.x=a[4].x-a[1].x; s3.y=a[4].y-a[1].y; s3.z=a[4].z-a[1].z; int ans=(s1.x*s2.y*s3.z+s1.y*s2.z*s3.x+s1.z*s2.x*s3.y-s1.z*s2.y*s3.x-s1.x*s2.z*s3.y-s1.y*s2.x*s3.z); if(ans==0) printf("Yes\n"); else printf("No\n"); }}
View Code

 

转载于:https://www.cnblogs.com/Roni-i/p/7570621.html

你可能感兴趣的文章
Bzoj2251 [2010Beijing Wc]外星联络
查看>>
python 发送邮件
查看>>
在凡客四个月的工作总结
查看>>
Qt颜色下拉框
查看>>
31、springboot与任务
查看>>
【转】 一个fork的面试题
查看>>
20131108
查看>>
django.http.request中HttpRequest对象的一些属性与方法
查看>>
英文对应解释
查看>>
Robotics ToolBox机械臂仿真
查看>>
linux添加环境变量
查看>>
【uva 1312】Cricket Field(算法效率--技巧枚举)
查看>>
VS2017 MVC项目,新建控制器提示未能加载文件或程序集“Dapper.Contrib解决方法
查看>>
【ora-err】ORA-03113: end-of-file on communication channel
查看>>
00.索引-综述
查看>>
strcpy
查看>>
AC3 Rematrix
查看>>
C#之Windows Form Application与attribute
查看>>
函数与指针分析实例
查看>>
爬虫:pycurl模块的使用说明
查看>>