- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在我的寻路程序中使用多边形函数中的这个点。
int point_in_pol(int vertcount, float *vertx, float *verty, int vertexx, int vertexy){
double vertexx1;
vertexx1 = vertexx;
double vertexy1;
vertexy1 = vertexy;
int i ,j, c = 0;
for (i = 0, j = vertcount-1; i < vertcount; j = i++) {
if ( (((verty[i]>=vertexy1) && (verty[j]<=vertexy1) ) || ((verty[i]<=vertexy1) && (verty[j]>=vertexy1) )) &&
(vertexx1 < (vertx[j]-vertx[i]) * (vertexy1-verty[i]) / (verty[j]-verty[i]) + vertx[i]) )
c = !c;
}
return c;
}
如果点在多边形中,则此函数返回 true。但是,如果给定的点位于多边形的边缘,则它不会正常运行。如果该点位于边缘,我应该在此处进行哪些更改以使其返回 true?
完整代码:
#include <stdio.h>
#include <conio.h>
#include <stdlib.h>
#include <time.h>
#include <string.h>
typedef struct Node Node;
typedef struct Qnode Qnode;
void enqueue(Node* node);
void enqueue_left(Node* node);
Node* generate(int x, int y);
Node* dequeue();
void expand(Node* node, int xend, int yend);
int point_in_pol(int vertcount, float *vertx, float *verty, int vertexx, int vertexy);
struct Node{
Node* predecessor;
Node* up;
Node* down;
Node* left;
Node* right;
int xpos;
int ypos;
int marked;
};
struct Qnode{
Qnode* next;
Node* Gnode;
};
Qnode* front = NULL;
Qnode* rear = NULL;
int queuesize = 0;
int des;
int solutioncost = 0;
Node* closednodes[80000];
int nodesclosed = 0;
float polygonx[20][50];
float polygony[20][50];
int polycount = 0, vertcount = 0;
int vertcounts[20];
void enqueue(Node* node){
if (queuesize == 0){
rear = (Qnode*)malloc(sizeof(Qnode));
rear->Gnode = node;
rear->next = NULL;
front = rear;
}
else{
Qnode* temp = (Qnode*)malloc(sizeof(Qnode));
rear->next = temp;
temp->Gnode = node;
temp->next = NULL;
rear = temp;
}
queuesize++;
}
void enqueue_left(Node* node){
if(queuesize == 0){
front = (Qnode*)malloc(sizeof(Qnode));
front->Gnode = node;
front->next = NULL;
rear = front;
}
else{
Qnode* temp = (Qnode*)malloc(sizeof(Qnode));
temp->Gnode = node;
temp->next = front;
front = temp;
}
queuesize++;
}
Node* dequeue(){
Qnode* temp = front;
if (queuesize == 0){
printf("Error!");
}
else{
Node* temp1 = front->Gnode;
temp = front->next;
free(front);
front = temp;
queuesize--;
return temp1;
}
}
Node* generate(int x, int y){
int i = 0, j = 0;
//printf("Generating node (%d,%d)...\n", x, y);
if ((x >0 && x <=400) && (y >0 && y <=200)){
Node* temp = (Node*)malloc(sizeof(Node));
temp->xpos = x;
temp->ypos = y;
temp->marked = 0;
for(i; i<polycount; i++){
if(point_in_pol(vertcounts[i], polygonx[i],polygony[i], x, y)){
temp->marked = 1;
}
}
temp->up = NULL;
temp->predecessor = NULL;
temp->down = NULL;
temp->left = NULL;
temp->right = NULL;
return temp;
}
else{
printf("Invalid starting point! \n");
}
}
void expand(Node* node, int xend, int yend){
//printf("Expanding node (%d, %d)...\n", node->xpos, node->ypos);
solutioncost++;
int flag = 0;
closednodes[nodesclosed] = node;
nodesclosed++;
dequeue();
if(node->marked == 1){
// printf("Cannot expand. Part of a polygon.\n");
}
else{
if (node->xpos == xend && node->ypos == yend){
printf("Node reached!");
printf("Path in reverse order: \n(%d, %d)\n", xend, yend);
while(node->predecessor!= NULL){
printf("(%d, %d)\n", node->predecessor->xpos, node->predecessor->ypos);
node = node->predecessor;
}
queuesize = 0;
return;
}
if (node->xpos-1 >0 && node->left == NULL){
int k = 0;
int j = 0;
Qnode* temp2 = front;
for(k; k<queuesize; k++){
int xx = temp2->Gnode->xpos;
int yy = temp2->Gnode->ypos;
if (xx == node->xpos-1 && yy == node->ypos)
flag = 1;
temp2 = temp2->next;
}
for(j; j<nodesclosed; j++){
int xx = closednodes[j]->xpos;
int yy = closednodes[j]->ypos;
if (xx == node->xpos-1 && yy == node->ypos)
flag = 1;
}
if (flag == 0){
node->left = generate(node->xpos-1, node->ypos);
node->left->predecessor = node;
node->left->right = node;
if(des == 1)
enqueue(node->left);
else if(des == 2)
enqueue_left(node->left);
}
else{
//printf("(%d, %d) not generated.\n", node->xpos-1, node->ypos);
flag = 0;
}
}
if (node->xpos+1 <=400 && node->right ==NULL){
int k = 0;
int j = 0;
Qnode* temp2 = front;
for(k; k<queuesize; k++){
int xx = temp2->Gnode->xpos;
int yy = temp2->Gnode->ypos;
if (xx == node->xpos+1 && yy == node->ypos)
flag = 1;
temp2 = temp2->next;
}
for(j; j<nodesclosed; j++){
int xx = closednodes[j]->xpos;
int yy = closednodes[j]->ypos;
if (xx == node->xpos+1 && yy == node->ypos)
flag = 1;
}
if (flag == 0){
node->right = generate(node->xpos+1, node->ypos);
node->right->predecessor = node;
node->right->left = node;
if(des == 1)
enqueue(node->right);
else if(des == 2)
enqueue_left(node->right);
}
else{
//printf("(%d, %d) not generated.\n", node->xpos+1, node->ypos);
flag = 0;
}
}
if (node->ypos+1 <=200 && node->up ==NULL){
int k = 0;
int j = 0;
Qnode* temp2 = front;
for(k; k<queuesize; k++){
int xx = temp2->Gnode->xpos;
int yy = temp2->Gnode->ypos;
if (xx == node->xpos && yy == node->ypos+1)
flag = 1;
temp2 = temp2->next;
}
for(j; j<nodesclosed; j++){
int xx = closednodes[j]->xpos;
int yy = closednodes[j]->ypos;
if (xx == node->xpos && yy == node->ypos+1)
flag = 1;
}
if (flag ==0){
node->up = generate(node->xpos, node->ypos+1);
node->up->predecessor = node;
node->up->down = node;
if(des == 1)
enqueue(node->up);
else if(des == 2)
enqueue_left(node->up);
}
else{
//printf("(%d, %d) not generated.\n", node->xpos, node->ypos+1);
flag = 0;
}
}
if (node->ypos-1 >0 && node->down ==NULL){
int k = 0;
int j = 0;
Qnode* temp2 = front;
for(k; k<queuesize; k++){
int xx = temp2->Gnode->xpos;
int yy = temp2->Gnode->ypos;
if (xx == node->xpos && yy == node->ypos-1)
flag = 1;
temp2 = temp2->next;
}
for(j; j<nodesclosed; j++){
int xx = closednodes[j]->xpos;
int yy = closednodes[j]->ypos;
if (xx == node->xpos && yy == node->ypos-1)
flag = 1;
}
if (flag ==0){
node->down = generate(node->xpos, node->ypos-1);
node->down->predecessor = node;
node->down->up = node;
if(des == 1)
enqueue(node->down);
else if(des == 2)
enqueue_left(node->down);
}
else{
// printf("(%d, %d) not generated.\n", node->xpos, node->ypos-1);
flag = 0;
}
}
return;
}
}
int point_in_pol(int vertcount, float *vertx, float *verty, int vertexx, int vertexy){
double vertexx1;
vertexx1 = vertexx;
double vertexy1;
vertexy1 = vertexy;
int i ,j, c = 0;
for (i = 0, j = vertcount-1; i < vertcount; j = i++) {
if ( (((verty[i]>=vertexy1) && (verty[j]<=vertexy1) ) || ((verty[i]<=vertexy1) && (verty[j]>=vertexy1) )) &&
(vertexx1 < (vertx[j]-vertx[i]) * (vertexy1-verty[i]) / (verty[j]-verty[i]) + vertx[i]) )
c = !c;
// if ((vertexx1 == ((vertx[j]-vertx[i]) * (vertexy1-verty[i]) / (verty[j]-verty[i])+ vertx[i])) )
// return 1;
}
return c;
}
int main(){
printf("\nFILE NUMBER 1\n");
int x_start, y_start, x_end, y_end;
clock_t begin, end;
double time_spent;
FILE *fp;
fp = fopen("1.txt", "r");
if (fp == NULL)
printf("Error printing output. \n");
else
fscanf(fp, "(%d,%d)\n", &x_start, &y_start);
fscanf(fp, "(%d,%d)\n", &x_end, &y_end);
printf("Starting point is (%d, %d)\n", x_start, y_start);
printf("Ending point is (%d, %d)\n", x_end, y_end);
char temp3[255];
char* source;
int t;
while(fgets(temp3, 255, fp)!= NULL){
source = temp3;
t = 0;
printf("Polygon %d: ", polycount);
while(sscanf(source, "(%f,%f)%*[^(]%n", &polygonx[polycount][vertcount], &polygony[polycount][vertcount], &t) == 2){
printf("(%.2f,%.2f),",polygonx[polycount][vertcount], polygony[polycount][vertcount]);
source+=t;
vertcount++;
}
printf("\n");
vertcounts[polycount] = vertcount;
vertcount = 0;
polycount++;
}
printf("Select a search algorithm:\n 1. BFS\n 2: DFS\n 3: A*");
scanf("%d", &des);
if (des == 1 || des == 2){
begin = clock();
Node* start = generate(x_start, y_start);
enqueue(start);
while(queuesize!=0){
expand(front->Gnode, x_end, y_end);
}
end = clock();
time_spent = (double)(end - begin) / CLOCKS_PER_SEC;
printf("Solution cost is: %d.\n", solutioncost);
printf("Running time is %f.\n", time_spent);
fclose(fp);
}
}
将其用作 1.txt 的输入:
(4,4)
(1,1)
(3,2),(2,2),(2,3),(3,3)
没有答案
最佳答案
int
point_in_pol(int vertcount, float *vertx, float *verty,
int vertexx, int vertexy)
{
double vertexx1;
vertexx1 = vertexx;
double vertexy1;
vertexy1 = vertexy;
int i ,j, c = 0;
for (i = 0, j = vertcount-1; i < vertcount; j = i++)
{
if ( (((verty[i]>=vertexy1) && (verty[j]<=vertexy1) )
|| ((verty[i]<=vertexy1) && (verty[j]>=vertexy1))) // this checks
// whether y-coord
// i.e. vertexy1 is
// between edge's
// vertices
&& (vertexx1 < (vertx[j]-vertx[i])
* (vertexy1-verty[i]) / (verty[j]-verty[i])
+ vertx[i]) ) // this checks
// whether x-coord
// i.e. vertexx1
// is to the left
// of the line
c = !c;
}
return c;
}
该算法的原型(prototype)名为pnpoly,其解释可见here .它的局限性之一是它无法处理恰好位于边界上的点,即它无法说明何时是这种情况。
(边界)边上的点
Pnpoly 将平面划分为多边形内部的点和多边形外部的点。边界上的点被分类为内部或外部。
我认为这应该可以解决问题:
if (vertexx1 == (vertx[j]-vertx[i])
* (vertexy1-verty[i]) / (verty[j]-verty[i])
+ vertx[i]) ) // this will check if vertexx1
// is equal to x-coordinate
// of what would have point on the
// edge with y=vertexy1 had
return 1;
但是你应该小心浮点错误。计算舍入误差会使结果错误。您可以添加 epsilon 比较:
if (fabs(vertexx1 - (vertx[j]-vertx[i])
* (vertexy1-verty[i]) / (verty[j]-verty[i])
- vertx[i]) < EPSILON)
return 1;
关于c - 在此 pnpoly 算法中包括边,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32807037/
127.0.0.1:8000/api/仅包含来自第二个应用程序的 url,但我将两个 url 模块链接到相同的模式。甚至有可能做到这一点吗? 第一个应用程序: from django.urls imp
我目前正在学习 ColdFusion。我有 PHP 背景,对此我有点困惑。 我有一个选择菜单,我希望将选项保存在不同的文件中。 (例如 options.cfm)当我调用文件时,我想在选择菜单中包含选项
字符串: "75,000", "is", "95%", "or", "95/100" "of", "monthly", "income" o/p: "is","%, "or", "/", "of",
我有 4 个 javascript 文件(每个文件对应一个 HTML 文件),所有 4 个文件中的 3 个函数都是相同的。我想找到一个顺利的解决方案,我可以以某种方式分别包含这 3 个函数...是否可
我在 PHP 中有这种情况,其中 include在一台服务器上被遗漏,但在另一台服务器上没有(我没有设置服务器,所以我不能告诉你更多;我不是真正的 devops 人,所以这就是我在这里问的原因)。两台
这是一个模式文件,midi.xsd定义类型,note ,用于存储 MIDI 音符值: 这是另一个模式文件,octaves.xsd使用
我想备份以下文件夹 /home /etc /usr/local /root /var /boot 并排除 /var/tmp /var/run /var/lock /home/*/.thumbnails
如何重新编码具有许多值(包括缺失值)的数值变量,以获得数字 0:n-1哪里n是唯一值的数量,包括 NA ,整齐? 例子: df 1 1000 0 2 1000 0 3 N
选择元素的 html(包括在内)的最佳方法是什么?例如: This is just a test. 而$('#testDiv').html()返回"This is just a test."
我正在尝试设置Varnish来处理本地环境中的ESI包含。 我在虚拟机中运行 Varnish ,内容在主机上运行。 我有两个文件“index.html”和“test.html”。它们都存储在apach
我有以下内容,并且想要检索“ FromEmail”不为空的数据 Simple email@gma
欧海,我正在编写一个小型 PHP 应用程序,使用一个单独的 config.php 文件和一个functions.php,其中包含我将在应用程序中使用的所有自定义函数。现在,我真的必须在每个函数中包含
我知道可以将 JavaScript 放在一个特定的 .js 文件中,然后通过执行以下操作将其包含在任何页面中...... 我注意到,对于包含的这些 .js 文件: 它们实际上不必以 .js 结尾 其
我使用 gwt UIBinder 添加了一些项目到我的 ComboBox。 --select one-- Dispute Referral Form Dispute Settlement Clause
我可以将一个 first.c 文件包含到另一个 second.c 中吗? (我正在做一些套接字编程,以将服务器收到的消息存储在链接列表中,因此在第一个程序中,我尝试保留链接列表和第二个程序套接字编程文
我有一个简单的 Spring MVC 数据项目设置,我试图选择 Admin 中尚不存在的用户列表。 table 。这是我的存储库方法 SELECT u FROM User u WHERE u.id N
在 bash 脚本中,使用什么实用程序以及如何删除两个字符串之间的文本,包括字符串。 原文: (ABC blah1)blah 2(def blah 5)blah 7)(DEF blah 8)blah
我有这个 BST 问题,我试图用 Java 解决,但我不知道为什么它不起作用。问题是: 二叉搜索树 (BST) 是一种二叉树,其中每个值节点大于或等于该节点的所有节点中的值左子树并且小于该树中所有节点
我有一个字符串,其中包含“Dollars”和“Cents”符号。我想删除它们。我试过了 string.replaceAll("[\"\\u00A2\" $]", "") 但它不起作用。正确的做法是什么
我在 stories 和 tags 之间有一个多对多的关系,为保存关系而创建的表是 taxonomies。我想搜索所有具有所有给定标签的故事。 到目前为止我使用的查询是这个,当然它对我不起作用,它返回
我是一名优秀的程序员,十分优秀!