Chinaunix首页 | 论坛 | 博客
  • 博客访问: 50105
  • 博文数量: 12
  • 博客积分: 291
  • 博客等级: 二等列兵
  • 技术积分: 147
  • 用 户 组: 普通用户
  • 注册时间: 2010-05-15 14:25
文章分类

全部博文(12)

文章存档

2011年(12)

我的朋友

分类: C/C++

2011-08-25 21:02:24

  1. #include <tchar.h>
  2. #include <iostream>
  3. #include <math.h>
  4. using namespace std;

  5. struct Point
  6. {
  7.     Point()
  8.     {
  9.         dX = 0.0;
  10.         dY = 0.0;
  11.     }
  12.     double dX;
  13.     double dY;
  14. };

  15. //    第一条直线式:a11X + a12Y = b1
  16. //    第二条直线式:a21X + a22Y = b2
  17. //    利用行列式计算交点
  18. //    返回值 true -- 函数执行成功, false -- 函数执行失败(两条直线平行)
  19. bool BeeLineInterSection(double da11, double da12, double db1, double da21, double da22, double db2, Point& PtInterSection)
  20. {
  21.     double dD = da11 * da22 - da21 * da12;
  22.     if (fabs(dD) < 0.0001)
  23.     {
  24.         return false;
  25.     }

  26.     double dD1 = db1 * da22 - db2 * da12;
  27.     double dD2 = da11 * db2 - da21 * db1;
  28.     PtInterSection.dX = dD1 / dD;
  29.     PtInterSection.dX = dD2 / dD;
  30.     return true;
  31. }

  32. int _tmain(int argc, TCHAR* argv[], TCHAR* envp[])
  33. {
  34.     /* 计算下列两个直线的交点
  35.     X + 3Y = 1
  36.     2X - 4Y = 5
  37.     */

  38.     Point PtResult;
  39.     if(BeeLineInterSection(1, 3, 1, 2, -4, 5, PtResult))
  40.     {
  41.         cout << PtResult.dX << _T(" ") << PtResult.dY << endl;
  42.     }
  43.     else
  44.     {
  45.         cout << _T("两条直线没有交点") << endl;
  46.     }
  47.     return 0;
  48. }
阅读(890) | 评论(0) | 转发(0) |
0

上一篇:没有了

下一篇:C++中,关于#include<***.h>和#include"***.h"的区别

给主人留下些什么吧!~~