hdu 4617 2013多校联合训练第二场weapon简单的计算几何

2024-06-07 07:32

本文主要是介绍hdu 4617 2013多校联合训练第二场weapon简单的计算几何,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

多校训练的题都比较难,但这题还是比较水的,就是判断空间任意2个中无限长的圆柱体是否相交或相切

细节说明可以看代码的注释

#include<cstdio>
#include<algorithm>
#include<cmath>
#define INF 1e9
#define eps 1e-8
using namespace std;
struct Point {double x,y,z;};
typedef Point Vec;
struct Yuanzhu{double r;Vec N;Point center;}team[50];
double inline Veclen(Vec u)//计算模长
{return  sqrt(u.x*u.x+u.y*u.y+u.z*u.z);
}
Point inline Jian(Point a,Point b)//2个点相减
{return (Point){a.x-b.x,a.y-b.y,a.z-b.z};
}
double inline DianJi(Vec a,Vec b)//点积
{return a.x*b.x+a.y*b.y+a.z*b.z;
}
Vec inline ChaJi(Vec a,Vec b)//叉积
{return (Vec){a.y*b.z-b.y*a.z,b.x*a.z-a.x*b.z,a.x*b.y-b.x*a.y};
}
bool inline Zero(double a)//浮点判零
{return a<eps&&a>-eps;
}
double dis(Yuanzhu a,Yuanzhu b)//算2个圆柱间的距离
{Vec AB=Jian(a.center,b.center);//圆心连接的构成的向量Vec N=ChaJi(a.N,b.N);if(Zero(N.x)&&Zero(N.y)&&Zero(N.z)) N=a.N;//如果2个圆柱平行double ans;ans=DianJi(AB,N)/Veclen(N);//计算2个圆柱的过圆心的直线的最小距离,注意可能为负值if(ans<0) ans=-ans;//为负值就取其绝对值return ans-a.r-b.r;//减去2个圆柱的半径,就得到了2个圆柱的最小距离,为负值的时候说明2个圆柱相交,0的时候相切
}
void inline scan(Point &a) { scanf("%lf%lf%lf",&a.x,&a.y,&a.z); }//读入一个点的函数
int n;
void read()
{scanf("%d",&n);for(int i=0;i<n;i++){Point a,b;scan(team[i].center);scan(a);scan(b);team[i].r=Veclen(Jian(team[i].center,a));team[i].N=ChaJi(Jian(a,b),Jian(team[i].center,a));}
}
void deal()
{double ans=INF;for(int i=0;i<n;i++)for(int j=i+1;j<n;j++)//枚举2个圆柱的距离{double temp=dis(team[i],team[j]);if(temp<eps)//判断是否相交{printf("Lucky\n");return ;}ans=min(ans,temp);}printf("%.2lf\n",ans);
}
int main()
{int T;scanf("%d",&T);while(T--){read();deal();}return 0;
}


 

这篇关于hdu 4617 2013多校联合训练第二场weapon简单的计算几何的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1038536

相关文章

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个

hdu2289(简单二分)

虽说是简单二分,但是我还是wa死了  题意:已知圆台的体积,求高度 首先要知道圆台体积怎么求:设上下底的半径分别为r1,r2,高为h,V = PI*(r1*r1+r1*r2+r2*r2)*h/3 然后以h进行二分 代码如下: #include<iostream>#include<algorithm>#include<cstring>#include<stack>#includ

usaco 1.3 Prime Cryptarithm(简单哈希表暴搜剪枝)

思路: 1. 用一个 hash[ ] 数组存放输入的数字,令 hash[ tmp ]=1 。 2. 一个自定义函数 check( ) ,检查各位是否为输入的数字。 3. 暴搜。第一行数从 100到999,第二行数从 10到99。 4. 剪枝。 代码: /*ID: who jayLANG: C++TASK: crypt1*/#include<stdio.h>bool h

usaco 1.3 Mixing Milk (结构体排序 qsort) and hdu 2020(sort)

到了这题学会了结构体排序 于是回去修改了 1.2 milking cows 的算法~ 结构体排序核心: 1.结构体定义 struct Milk{int price;int milks;}milk[5000]; 2.自定义的比较函数,若返回值为正,qsort 函数判定a>b ;为负,a<b;为0,a==b; int milkcmp(const void *va,c

poj 3974 and hdu 3068 最长回文串的O(n)解法(Manacher算法)

求一段字符串中的最长回文串。 因为数据量比较大,用原来的O(n^2)会爆。 小白上的O(n^2)解法代码:TLE啦~ #include<stdio.h>#include<string.h>const int Maxn = 1000000;char s[Maxn];int main(){char e[] = {"END"};while(scanf("%s", s) != EO

hdu 2093 考试排名(sscanf)

模拟题。 直接从教程里拉解析。 因为表格里的数据格式不统一。有时候有"()",有时候又没有。而它也不会给我们提示。 这种情况下,就只能它它们统一看作字符串来处理了。现在就请出我们的主角sscanf()! sscanf 语法: #include int sscanf( const char *buffer, const char *format, ... ); 函数sscanf()和

hdu 2602 and poj 3624(01背包)

01背包的模板题。 hdu2602代码: #include<stdio.h>#include<string.h>const int MaxN = 1001;int max(int a, int b){return a > b ? a : b;}int w[MaxN];int v[MaxN];int dp[MaxN];int main(){int T;int N, V;s

uva 10387 Billiard(简单几何)

题意是一个球从矩形的中点出发,告诉你小球与矩形两条边的碰撞次数与小球回到原点的时间,求小球出发时的角度和小球的速度。 简单的几何问题,小球每与竖边碰撞一次,向右扩展一个相同的矩形;每与横边碰撞一次,向上扩展一个相同的矩形。 可以发现,扩展矩形的路径和在当前矩形中的每一段路径相同,当小球回到出发点时,一条直线的路径刚好经过最后一个扩展矩形的中心点。 最后扩展的路径和横边竖边恰好组成一个直

hdu 1754 I Hate It(线段树,单点更新,区间最值)

题意是求一个线段中的最大数。 线段树的模板题,试用了一下交大的模板。效率有点略低。 代码: #include <stdio.h>#include <string.h>#define TREE_SIZE (1 << (20))//const int TREE_SIZE = 200000 + 10;int max(int a, int b){return a > b ? a :

hdu 1166 敌兵布阵(树状数组 or 线段树)

题意是求一个线段的和,在线段上可以进行加减的修改。 树状数组的模板题。 代码: #include <stdio.h>#include <string.h>const int maxn = 50000 + 1;int c[maxn];int n;int lowbit(int x){return x & -x;}void add(int x, int num){while