亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? 浮點函數(shù).txt

?? 各種典型的算法集錦
?? TXT
字號:
//浮點幾何函數(shù)庫
#include <math.h>
#define eps 1e-8
#define zero(x) (((x)>0?(x):-(x))<eps)
struct point{double x,y;};
struct line{point a,b;};

//計算cross product (P1-P0)x(P2-P0)
double xmult(point p1,point p2,point p0){
	return (p1.x-p0.x)*(p2.y-p0.y)-(p2.x-p0.x)*(p1.y-p0.y);
}
double xmult(double x1,double y1,double x2,double y2,double x0,double y0){
	return (x1-x0)*(y2-y0)-(x2-x0)*(y1-y0);
}

//計算dot product (P1-P0).(P2-P0)
double dmult(point p1,point p2,point p0){
	return (p1.x-p0.x)*(p2.x-p0.x)+(p1.y-p0.y)*(p2.y-p0.y);
}
double dmult(double x1,double y1,double x2,double y2,double x0,double y0){
	return (x1-x0)*(x2-x0)+(y1-y0)*(y2-y0);
}

//兩點距離
double distance(point p1,point p2){
	return sqrt((p1.x-p2.x)*(p1.x-p2.x)+(p1.y-p2.y)*(p1.y-p2.y));
}
double distance(double x1,double y1,double x2,double y2){
	return sqrt((x1-x2)*(x1-x2)+(y1-y2)*(y1-y2));
}

//判三點共線
int dots_inline(point p1,point p2,point p3){
	return zero(xmult(p1,p2,p3));
}
int dots_inline(double x1,double y1,double x2,double y2,double x3,double y3){
	return zero(xmult(x1,y1,x2,y2,x3,y3));
}

//判點是否在線段上,包括端點
int dot_online_in(point p,line l){
	return zero(xmult(p,l.a,l.b))&&(l.a.x-p.x)*(l.b.x-p.x)<eps&&(l.a.y-p.y)*(l.b.y-p.y)<eps;
}
int dot_online_in(point p,point l1,point l2){
	return zero(xmult(p,l1,l2))&&(l1.x-p.x)*(l2.x-p.x)<eps&&(l1.y-p.y)*(l2.y-p.y)<eps;
}
int dot_online_in(double x,double y,double x1,double y1,double x2,double y2){
	return zero(xmult(x,y,x1,y1,x2,y2))&&(x1-x)*(x2-x)<eps&&(y1-y)*(y2-y)<eps;
}

//判點是否在線段上,不包括端點
int dot_online_ex(point p,line l){
	return dot_online_in(p,l)&&(!zero(p.x-l.a.x)||!zero(p.y-l.a.y))&&(!zero(p.x-l.b.x)||!zero(p.y-l.b.y));
}
int dot_online_ex(point p,point l1,point l2){
	return dot_online_in(p,l1,l2)&&(!zero(p.x-l1.x)||!zero(p.y-l1.y))&&(!zero(p.x-l2.x)||!zero(p.y-l2.y));
}
int dot_online_ex(double x,double y,double x1,double y1,double x2,double y2){
	return dot_online_in(x,y,x1,y1,x2,y2)&&(!zero(x-x1)||!zero(y-y1))&&(!zero(x-x2)||!zero(y-y2));
}

//判兩點在線段同側,點在線段上返回0
int same_side(point p1,point p2,line l){
	return xmult(l.a,p1,l.b)*xmult(l.a,p2,l.b)>eps;
}
int same_side(point p1,point p2,point l1,point l2){
	return xmult(l1,p1,l2)*xmult(l1,p2,l2)>eps;
}

//判兩點在線段異側,點在線段上返回0
int opposite_side(point p1,point p2,line l){
	return xmult(l.a,p1,l.b)*xmult(l.a,p2,l.b)<-eps;
}
int opposite_side(point p1,point p2,point l1,point l2){
	return xmult(l1,p1,l2)*xmult(l1,p2,l2)<-eps;
}

// 點關于直線的對稱點 // by lyt
// 缺點:用了斜率
// 也可以利用"點到直線上的最近點"來做,避免使用斜率。
point symmetric_point(point p1, point l1, point l2) {
  point ret;  
  if (l1.x > l2.x - eps && l1.x < l2.x + eps) {
    ret.x = (2 * l1.x - p1.x);
	ret.y = p1.y;
  } else {
    double k = (l1.y - l2.y ) / (l1.x - l2.x);
    ret.x = (2*k*k*l1.x + 2*k*p1.y - 2*k*l1.y - k*k*p1.x + p1.x) / (1 + k*k);
    ret.y = p1.y - (ret.x - p1.x ) / k;
  }
  return ret;
}

//判兩直線平行
int parallel(line u,line v){
	return zero((u.a.x-u.b.x)*(v.a.y-v.b.y)-(v.a.x-v.b.x)*(u.a.y-u.b.y));
}
int parallel(point u1,point u2,point v1,point v2){
	return zero((u1.x-u2.x)*(v1.y-v2.y)-(v1.x-v2.x)*(u1.y-u2.y));
}

//判兩直線垂直
int perpendicular(line u,line v){
	return zero((u.a.x-u.b.x)*(v.a.x-v.b.x)+(u.a.y-u.b.y)*(v.a.y-v.b.y));
}
int perpendicular(point u1,point u2,point v1,point v2){
	return zero((u1.x-u2.x)*(v1.x-v2.x)+(u1.y-u2.y)*(v1.y-v2.y));
}

//判兩線段相交,包括端點和部分重合
int intersect_in(line u,line v){
	if (!dots_inline(u.a,u.b,v.a)||!dots_inline(u.a,u.b,v.b))
		return !same_side(u.a,u.b,v)&&!same_side(v.a,v.b,u);
	return dot_online_in(u.a,v)||dot_online_in(u.b,v)||dot_online_in(v.a,u)||dot_online_in(v.b,u);
}
int intersect_in(point u1,point u2,point v1,point v2){
	if (!dots_inline(u1,u2,v1)||!dots_inline(u1,u2,v2))
		return !same_side(u1,u2,v1,v2)&&!same_side(v1,v2,u1,u2);
	return dot_online_in(u1,v1,v2)||dot_online_in(u2,v1,v2)||dot_online_in(v1,u1,u2)||dot_online_in(v2,u1,u2);
}

//判兩線段相交,不包括端點和部分重合
int intersect_ex(line u,line v){
	return opposite_side(u.a,u.b,v)&&opposite_side(v.a,v.b,u);
}
int intersect_ex(point u1,point u2,point v1,point v2){
	return opposite_side(u1,u2,v1,v2)&&opposite_side(v1,v2,u1,u2);
}

//計算兩直線交點,注意事先判斷直線是否平行!
//線段交點請另外判線段相交(同時還是要判斷是否平行!)
point intersection(line u,line v){
	point ret=u.a;
	double t=((u.a.x-v.a.x)*(v.a.y-v.b.y)-(u.a.y-v.a.y)*(v.a.x-v.b.x))
			/((u.a.x-u.b.x)*(v.a.y-v.b.y)-(u.a.y-u.b.y)*(v.a.x-v.b.x));
	ret.x+=(u.b.x-u.a.x)*t;
	ret.y+=(u.b.y-u.a.y)*t;
	return ret;
}
point intersection(point u1,point u2,point v1,point v2){
	point ret=u1;
	double t=((u1.x-v1.x)*(v1.y-v2.y)-(u1.y-v1.y)*(v1.x-v2.x))
			/((u1.x-u2.x)*(v1.y-v2.y)-(u1.y-u2.y)*(v1.x-v2.x));
	ret.x+=(u2.x-u1.x)*t;
	ret.y+=(u2.y-u1.y)*t;
	return ret;
}

//點到直線上的最近點
point ptoline(point p,line l){
	point t=p;
	t.x+=l.a.y-l.b.y,t.y+=l.b.x-l.a.x;
	return intersection(p,t,l.a,l.b);
}
point ptoline(point p,point l1,point l2){
	point t=p;
	t.x+=l1.y-l2.y,t.y+=l2.x-l1.x;
	return intersection(p,t,l1,l2);
}

//點到直線距離
double disptoline(point p,line l){
	return fabs(xmult(p,l.a,l.b))/distance(l.a,l.b);
}
double disptoline(point p,point l1,point l2){
	return fabs(xmult(p,l1,l2))/distance(l1,l2);
}
double disptoline(double x,double y,double x1,double y1,double x2,double y2){
	return fabs(xmult(x,y,x1,y1,x2,y2))/distance(x1,y1,x2,y2);
}

//點到線段上的最近點
point ptoseg(point p,line l){
	point t=p;
	t.x+=l.a.y-l.b.y,t.y+=l.b.x-l.a.x;
	if (xmult(l.a,t,p)*xmult(l.b,t,p)>eps)
		return distance(p,l.a)<distance(p,l.b)?l.a:l.b;
	return intersection(p,t,l.a,l.b);
}
point ptoseg(point p,point l1,point l2){
	point t=p;
	t.x+=l1.y-l2.y,t.y+=l2.x-l1.x;
	if (xmult(l1,t,p)*xmult(l2,t,p)>eps)
		return distance(p,l1)<distance(p,l2)?l1:l2;
	return intersection(p,t,l1,l2);
}

//點到線段距離
double disptoseg(point p,line l){
	point t=p;
	t.x+=l.a.y-l.b.y,t.y+=l.b.x-l.a.x;
	if (xmult(l.a,t,p)*xmult(l.b,t,p)>eps)
		return distance(p,l.a)<distance(p,l.b)?distance(p,l.a):distance(p,l.b);
	return fabs(xmult(p,l.a,l.b))/distance(l.a,l.b);
}
double disptoseg(point p,point l1,point l2){
	point t=p;
	t.x+=l1.y-l2.y,t.y+=l2.x-l1.x;
	if (xmult(l1,t,p)*xmult(l2,t,p)>eps)
		return distance(p,l1)<distance(p,l2)?distance(p,l1):distance(p,l2);
	return fabs(xmult(p,l1,l2))/distance(l1,l2);
}

//矢量V以P為頂點逆時針旋轉angle并放大scale倍
point rotate(point v,point p,double angle,double scale){
	point ret=p;
	v.x-=p.x,v.y-=p.y;
	p.x=scale*cos(angle);
	p.y=scale*sin(angle);
	ret.x+=v.x*p.x-v.y*p.y;
	ret.y+=v.x*p.y+v.y*p.x;
	return ret;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91精品一区二区三区在线观看| 26uuu精品一区二区| 精品一区二区在线免费观看| 中文字幕一区二区三区四区不卡| 欧美mv和日韩mv国产网站| thepron国产精品| 极品少妇xxxx精品少妇| 亚洲成人7777| 亚洲欧美日韩国产成人精品影院| 久久久亚洲精华液精华液精华液 | 97精品久久久午夜一区二区三区 | 亚洲国产成人av网| 日韩理论片在线| 中文字幕久久午夜不卡| 精品国产凹凸成av人网站| 欧美另类变人与禽xxxxx| 91福利区一区二区三区| 成人一级黄色片| 国模无码大尺度一区二区三区| 午夜日韩在线观看| 亚洲午夜免费视频| 亚洲欧美日韩一区二区三区在线观看 | 日韩avvvv在线播放| 亚洲国产一二三| 一区二区三区鲁丝不卡| 综合在线观看色| 国产精品网友自拍| 国产精品区一区二区三| 久久蜜臀中文字幕| 久久夜色精品国产欧美乱极品| 日韩一区二区精品葵司在线| 在线不卡a资源高清| 欧美日韩视频在线第一区 | 成人福利在线看| 成人激情视频网站| eeuss鲁片一区二区三区在线观看| 国产成人免费视频一区| 国产成人午夜视频| 高清成人免费视频| aaa欧美色吧激情视频| 99久久99久久综合| 一本一道久久a久久精品| 91女人视频在线观看| 欧洲精品一区二区三区在线观看| 在线精品视频一区二区三四| 欧美制服丝袜第一页| 欧美日韩精品系列| 日韩午夜av一区| 久久久久久久久久看片| 国产精品免费人成网站| 亚洲欧美偷拍另类a∨色屁股| 亚洲精品少妇30p| 视频在线在亚洲| 久久99精品国产麻豆婷婷洗澡| 国产激情视频一区二区在线观看 | 欧美一二三四区在线| 日韩精品一区在线| 久久精品欧美一区二区三区麻豆| 中文字幕欧美区| 夜夜精品视频一区二区| 日韩中文字幕91| 国产高清不卡一区| 色综合婷婷久久| 欧美一区二区三区成人| 久久久亚洲国产美女国产盗摄| 中文字幕一区二区三区蜜月| 亚洲第一电影网| 精品影院一区二区久久久| 高清日韩电视剧大全免费| 色老综合老女人久久久| 91精品国产欧美一区二区| 国产日韩三级在线| 一区二区三区免费看视频| 久久精品免费观看| 99re这里只有精品首页| 日韩一级片网址| 国产精品一区二区黑丝| 蜜臀国产一区二区三区在线播放| 国产一区二区三区黄视频| 91蜜桃婷婷狠狠久久综合9色| 91精品国产高清一区二区三区蜜臀| 久久久久久久综合狠狠综合| 一区二区不卡在线播放 | 国产一区二区三区综合| 99久久久久免费精品国产| 538在线一区二区精品国产| 国产性天天综合网| 天堂精品中文字幕在线| 国产99一区视频免费| 欧美日韩激情在线| 中文字幕高清一区| 蜜臀av一级做a爰片久久| 97精品电影院| 久久综合久久99| 亚洲成人一区在线| 99久久综合精品| 精品久久久三级丝袜| 亚洲狠狠爱一区二区三区| 粉嫩蜜臀av国产精品网站| 欧美一三区三区四区免费在线看| 成人欧美一区二区三区白人| 韩国理伦片一区二区三区在线播放| 欧美性生活久久| 国产精品美女久久久久aⅴ| 男人操女人的视频在线观看欧美| 91在线云播放| 国产精品嫩草99a| 国内外成人在线| 91精品在线免费| 亚洲国产精品一区二区久久恐怖片| 国产精品亚洲专一区二区三区| 欧美久久久影院| 亚洲夂夂婷婷色拍ww47 | 色综合久久精品| 欧美国产视频在线| 精品亚洲成a人在线观看| 欧美日韩一区二区在线观看| 亚洲视频1区2区| 丁香激情综合国产| 久久精品视频一区二区三区| 久久精品国产99国产精品| 欧美日韩一本到| 亚洲一区二区美女| 日本国产一区二区| 亚洲欧美成aⅴ人在线观看| 91在线丨porny丨国产| 一区二区中文视频| 99国产欧美久久久精品| 欧美高清在线精品一区| 国产成人精品免费| 国产欧美精品日韩区二区麻豆天美| 国产一区二区三区免费看| 久久免费国产精品| 国产69精品久久99不卡| 欧美国产精品v| 成人av电影在线播放| 中文字幕中文在线不卡住| 91色婷婷久久久久合中文| 一区二区三区四区蜜桃| 91电影在线观看| 亚洲成人综合视频| 日韩一区二区影院| 极品美女销魂一区二区三区 | 国产在线播精品第三| 久久久久久久久久久久久久久99 | 色婷婷亚洲精品| 一级特黄大欧美久久久| 欧美日韩精品一区二区在线播放| 一区二区三区在线免费视频| 欧美无砖专区一中文字| 日韩精品亚洲专区| 日韩欧美视频在线| 国产剧情一区二区三区| 国产精品无圣光一区二区| 在线观看亚洲一区| 日本不卡的三区四区五区| 久久综合狠狠综合| 成人app网站| 亚洲韩国精品一区| 精品91自产拍在线观看一区| 成人免费视频视频在线观看免费| 18欧美亚洲精品| 欧美精品九九99久久| 国产一区二区三区在线观看精品 | 欧美一级日韩一级| 国内精品国产成人国产三级粉色 | 亚洲成a人片综合在线| 日韩欧美黄色影院| 成人av集中营| 日韩精品国产欧美| 国产农村妇女精品| 欧美性色综合网| 精品一区二区三区免费观看| 国产精品嫩草99a| 777xxx欧美| 99久久夜色精品国产网站| 天堂影院一区二区| 中文字幕在线一区免费| 欧美高清视频www夜色资源网| 国产另类ts人妖一区二区| 一区二区三区四区在线免费观看 | 日韩精品乱码免费| 中文av一区二区| 在线不卡免费欧美| av亚洲精华国产精华精华| 免费人成黄页网站在线一区二区| 日本一二三不卡| 欧美一区二区三区在线看| 成人免费高清视频| 久久国产精品一区二区| 亚洲老妇xxxxxx| 久久久无码精品亚洲日韩按摩| 色94色欧美sute亚洲线路一久 | 欧美三级在线看| 丁香五精品蜜臀久久久久99网站| 亚洲一级二级三级在线免费观看| 国产亚洲成aⅴ人片在线观看 | 久久精品一区蜜桃臀影院| 精品视频123区在线观看| 成人黄色777网|