语言判断点面位置关系系统.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
语言判断点面位置关系系统.doc

C语言判断点面位置关系系统 一:程序 /*此程序适用于任意复杂程度的单连通和复连通多边形区域*/ #includestdio.h #includestring.h #define M 36 /*给定多边形边数*/ float X[M],Y[M]; float x,y,t,s,Ymin,Ymax,C,D,sn=O,sp=O,xp,yp,l; int i,j=O,k=l; char ch[2]; void input() /*定义输入坐标函数*/ { printf(”Please input points made of area: \n”); for(i=0;iM;i++) { scanf(%f,%r,X[i],Y[i]); /*从键盘输入围成多边形的顶点坐标*/ } printf(”Please input one point:); scanf(n%f,%f,x,y); /* 从键盘任意输入一点 */ } float func(float n) /*定义求绝对值的函数*/ { if(n〉0) ( return n; } else { return (-n); } } float Min(float m,float n) /*定义求最小值的函数*/ { if(m=n) { return m; } else return n; float Max(float m,float n) /*定义求最大值的函数 { if(m〉=n) { return m; } else { return n; } } void simplefun() /*定义判断点是否在凸多边形上、内、外函数*/ { xp=(XL0]+Xl2J)/2; /*起点与第三点的巾点横坐.标5V yp=(Y[0]+Y[2])/2; /*起点与第三点的中点纵坐标*/ printf(xp=%f\typ=%f\n’’,xp,yp); for(i=0;iM-1 ;i++) { t=((X[i]-xp)*(Y[i+l ]-yp)-(Y[i]-yp)*(X[i+l ]-xp))/2; t 二 func(t); sn=sn+t; if(i==M-2) { sn=sn+func(((X[0]-xp)*(Y[M-l]-yp)-(Y[0]-yp)*(X[M-l]-xp))/2); /* 求出凸多 边形的总面积并输出*/ } } printf(sn=%f\n”,sn); for(i=0;iM-l;i++) { t=((X[i]-x)*(Y[i+l ]-y)-(Y[i]-y)*(X[i+l l-x))/2; t=func(t); if(t==O) { if((X[i]〉X[i+l]xX[i+l]xX[i])||(X[i]X[i+l]x〉X[i]xX[i+l])) { sp=0; /*如果给定点的横坐标在相邻两点横坐标之间, 则给定点与各个相邻顶点依次围成的面积之和sp赋值为0,并跳 出循环*/ break; } else if((X[i]==X[i+1 ])(( Y[i]Y[i+1 ]yY[i+1 ]y Y[i])||(Y[i] Y[i+1 ]yY[i]yY[i+1 ]))) sp=O; /*如果给定点的纵坐标在相邻两点纵坐标之间,并且相邻两点横 坐标相等 则sp=O,并跳出循环*/ break; } else if(x==X[i]y==Y[i]||x==X[i+l ]y==Y[i+l ]) { sp=O; /*如果给定点的坐标等于相邻两点任意一点的坐标,则sp=O,并 跳出循环*/ break; } } sp=sp+t; if(i=M-2) /*最后一点的情况必须单独讨论,同上*/ { l=func(((X[O]-x)*(Y[M-l ]-y)-(Y[O]-y)*(X[M-l ]-x))/2); if(l==O) if((X[O]X[M-1 1x〉X[M- 1 1xX[01)||(X[01X[M- 1 1x〉X[01xX[M- 1 ])) { sp=O; break; } else if((X[O]==X[M-1 ])((Y[O]Y[M-1 ]yY[M-l ]yY[O])||( Y[0] Y[M-1 ]yY[O]y Y[M-1]))) { sp=O; break; } else if(x==X[O]y==Y[O]||x==X[M-1 ]y==Y[M-1 ]) { sp=O; break; } } sp=sp+l; /*若前面的if都不执行,则sp就是给定点与各个相邻顶点依次围 成的真实的面积之和*/ } } 终得出结论*/ if(sp〉sn) printfCThis point (%f,%f) is out of the region\n,x,y); } else if(sp==sn) { print

文档评论(0)

ggkkppp + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档