如何理解C++实现程序方法

发布时间:2021-11-24 10:07:16 作者:柒染
来源:亿速云 阅读:210

这篇文章将为大家详细讲解有关如何理解C++实现程序方法,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

C++实现程序解决问题,本程序采用射线法,由待测试点(v)水平引出一条射线B(v,w),计算B与vl边线的交点数目,判断点是否落在外包矩形内。

采用射线法判断点是否在多边形内的C++语言程序。多年前,我自己实现了这样一个算法。但是随着时间的推移,我决定重写这个代码。

这是个C++语言的小算法的C++实现程序,本来不想放到这里。可是,当我自己要实现这样一个算法的时候,想在网上找个现成的,考察下来竟然一个符合需要的也没有。我对自己大学读书时写的代码没有信心,所以,决定重新写一个,并把它放到这里,以飨读者。也增加一下BLOG的点击量。

本算法里所指的多边形,是指由一系列点序列组成的封闭简单多边形。它的首尾点可以是或不是同一个点(不强制要求首尾点是同一个点)。这样的多边形可以是任意形状的,包括多条边在一条绝对直线上。因此,定义多边

为加快判别速度,首先计算多边形的外包矩形(rect_t),判断点是否落在外包矩形内,只有满足落在外包矩形内的条件的点,才进入下一步的计算。为此,引入外包矩形结构rect_t和求点集合的外包矩形内的方法vertices_get_extent。

int pt_in_poly ( const vertex_t* vl, int np, /* polygon vl with np vertices */   const vertex_t* v)   {   int i, j, k1, k2, c;   rect_t rc;   vertex_t w;   if (np < 3)   return 0;   vertices_get_extent(vl, np, &rc);   if (v->x < rc.min_x || v->x > rc.max_x || v->y < rc.min_y || v->y > rc.max_y)   return 0;   /* Set a horizontal beam l(*v, w) from v to the ultra right */   w.x = rc.max_x + DBL_EPSILON;   w.y = v->y;   c = 0; /* Intersection points counter */   for(i=0; i    {   j = (i+1) % np;   if(is_intersect(vl+i, vl+j, v, &w))   {   c++;   }   else if(vl[i].y==w.y)   {   k1 = (np+i-1)%np;   while(k1!=i && vl[k1].y==w.y)   k1 = (np+k1-1)%np;   k2 = (i+1)%np;   while(k2!=i && vl[k2].y==w.y)   k2 = (k2+1)%np;   if(k1 != k2 && is_same(v, &w, vl+k1, vl+k2)==0)   c++;   if(k2 <= i)   break;   i = k2;   }   }   return c%2;   }

本想配些插图说明问题,但是,C++实现程序的文章里放图片我还没用过。实践证明,本程序算法的适应性极强。但是,对于点正好落在多边形边上的极端情形,有可能得出2种不同的结果。

关于如何理解C++实现程序方法就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

推荐阅读:
  1. C++实现新年贺卡程序
  2. C++实现航空订票程序

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

c++

上一篇:如何理解Python程序转为EXE文件的正确实现方法

下一篇:c语言怎么实现含递归清场版扫雷游戏

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》