直线的交点

#include <iostream.h>

// 求两直线交点
// 直线 1 上的两点:(ax1, ay1), (ax2, ay2)
// 直线 2 上的两点:(bx1, by1), (bx2, by2)
// 返回值:true: 有交点,保存在 (ix, iy) 中
//    :false: 两直线平行
bool Intersection(double ax1, double ay1, double ax2, double ay2, double bx1, double by1, double bx2, double by2, double *ix, double *iy)
{
 double d = (ay2-ay1) * (bx2-bx1) - (by2-by1) * (ax2-ax1);

 if (d==0)
  return false; // 两直线平行就退出,避免除数为 0 的情况

 *ix = (
  (ax2-ax1)*(bx2-bx1)*(by1-ay1)+(ay2-ay1)*(bx2-bx1)*ax1-(by2-by1)*(ax2-ax1)*bx1
  ) / d;
 *iy = (
  (ay2-ay1)*(by2-by1)*(bx1-ax1)+(ax2-ax1)*(by2-by1)*ay1-(bx2-bx1)*(ay2-ay1)*by1
  ) / -d;

 return true;
}


void main()
{
 double ix, iy;

 // 简化示例,没有写 cin 语句。
 // 示例,求 (7,3)-(5,8) 和 (3,5)-(10,6) 的交点
 if ( Intersection(7,3,5,8, 3,5,10,6, &ix,&iy) )
  cout << ix << ", " << iy << endl;
 else
  cout << "两直线平行" << endl;
}

 

http://blog.163.com/zh_y_yang/blog/static/181552412201141710316982/

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值