如何理解C++实现程序方法
发表于:2025-02-03 作者:千家信息网编辑
千家信息网最后更新 2025年02月03日,这篇文章将为大家详细讲解有关如何理解C++实现程序方法,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。C++实现程序解决问题,本程序采用射线法,由待测试
千家信息网最后更新 2025年02月03日如何理解C++实现程序方法
这篇文章将为大家详细讲解有关如何理解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++实现程序方法就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
程序
C++
多边形
矩形
算法
方法
射线
文章
代码
内容
更多
知识
篇文章
语言
问题
首尾
不同
不错
为此
交点
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
创建aps服务器策略组
特别专栏 网络安全
西安通鑫园网络技术有限公司
行政机构层次数据库模型图
天津调度服务器安装云主机云空间
计算机web用什么软件开发
交易模型软件开发
数据库sql数据类型
设置网络安全端口
orcle数据库创建
c#更新本地数据库失败
开发软件要学数据库吗
服务器开机怎么进入安全模式
f12调用数据库地址
网络安全特点不包括
软件开发服务费项目成本
浙江网络技术培训班
苏州市软件开发
退役老兵打造网络技术
连接数据库安全验证
战术小队加入服务器闪退
榆林网络技术质量
数据库类型关系型数据库
便宜的塔式服务器品牌
潮型裤互联网科技有限公司
下列哪个数据库对象能直接从
金牌网络技术
浙江网络技术培训班
实用网络技术匿名ftp是
原神都分什么服务器