- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试制作一个程序来计算圆、三角形和 4 边形内的点数。我有大约 3500 个坐标,我希望能够找出这些形状内坐标的数量,例如对于圆,我想输入中心坐标和半径并找到计数。或者对于类似正方形的形状,我目前有一个公式可以取 4 个点,并使用冒泡排序,这样我就可以订购根据点计算面积的方式,但我认为我正在绕过这个错误顺便说一句,我才刚刚开始编写这段代码并将把它放上去,但请放心,因为我只是想在填充它之前先了解一下它。
#include <iostream>
#include <vector>
#include <cstdlib>
#include <ctime>
using namespace std;
void bubblesort(vector<double>& vec)
{
double s = vec.size();
for (int i=0; i<s; i++)
{
for (int j=i+1; j<s; j++)
{
if (vec[i] < vec[j])
{
double x = vec[i];
vec[i] = vec[j];
vec[j] = x;
}
}
}
}
void squarecount(vector<double>& a, vector<double>& b)
{
// I am thinking here to put the x,y coordinates, linking each two and getting 4 equations counting the number satisfying all 4 inequalities
}
int main ()
{
double a;
cout << "Please enter the corresponding numberthe shape for which you want to find the count of in your data;" << endl;
cout << "Circle (1)" << endl;
cout << "Triangle (2) " << endl;
cout << "4 Sided Polygon (3)" << endl;
cin >> a;
if ( a == 1)
{
return 0;
}
else if (a == 2)
{
return 0;
}
else if (a == 3)
{
vector<double> data1;
vector<double> data2;
// 4 Sided Polygon
double x1, x2, x3, x4, y1, y2, y3, y4;
cout << "Enter the first x coordinate then press enter, then the corresponding y coordinate" << endl;
cin >> data1[0];
cin >> data2[0];
cout << "Enter the second x coordinate then press enter, then the corresponding y coordinate" << endl;
cin >> data1[1];
cin >> data2[1];
cout << "Enter the second x coordinate then press enter, then the corresponding y coordinate" << endl;
cin >> data1[2];
cin >> data2[2];
cout << "Enter the second x coordinate then press enter, then the corresponding y coordinate" << endl;
cin >> data1[3];
cin >> data2[3];
bubblesort(data1);
bubblesort(data2);
}
else
{
cout << "Invalid Input!" << endl;
cout << "Please enter either 1 for a circle, 2 for a triangle or 3 for a a 4 sided pollygon" << endl;
}
}
最佳答案
首先,如果您想写入一个vector
,您应该先使用push_back(.)
或resize
vector 。我不确定您要将排序算法用于什么目的。
此外,无需重新发明轮子。如果一个点在多边形(或圆)内,则有现有的算法来检查。您需要做的就是针对所有点测试它并计算形状内的点数。圆是微不足道的:只需检查从你的点到中心的距离是否小于半径。多边形有点复杂:point in polygon . ray-casting, even-odd rule algorithm可以这样实现:
#include<iostream>
#include<vector>
#include<cmath>
using namespace std;
bool checkPoly(double x, double y, vector<double> xCorners, vector<double> yCorners){
int num=xCorners.size();
int j=num-1;
bool res=false;
for(int i=0;i<num;i++){
if((yCorners[i]>y) != (yCorners[j]>y) && (x<(xCorners[j]-xCorners[i])*(y-yCorners[i])/(yCorners[j]-yCorners[i])+xCorners[i])){
res = !res;
}
j=i;
}
return res;
}
bool checkCircle(double x, double y, double xCenter, double yCenter, double radius){
if(sqrt(pow(x-xCenter,2)+pow(y-yCenter,2)) < radius){
return true;
}
return false;
}
int main(){
//POLYGON
vector<double> xCorners;
vector<double> yCorners;
xCorners.push_back(3);
yCorners.push_back(2);
xCorners.push_back(5);
yCorners.push_back(6);
xCorners.push_back(8);
yCorners.push_back(4);
bool resPoly=false;
//CIRCLE
double xCenter=5;
double yCenter=4;
double radius=2.5;
bool resCircle=false;
for(int x=0;x<10;x++){
for(int y=0;y<10;y++){
resPoly=checkPoly(x,y,xCorners,yCorners);
resCircle=checkCircle(x,y,xCenter,yCenter,radius);
if(resPoly){
cout<<"("<<x<<", "<<y<<") is inside the polygon."<<endl;
}else{
cout<<"("<<x<<", "<<y<<") is outside the polygon."<<endl;
}
if(resCircle){
cout<<"("<<x<<", "<<y<<") is inside the circle."<<endl;
}else{
cout<<"("<<x<<", "<<y<<") is outside the circle."<<endl;
}
}
}
return 0;
}
在这里,检查是否所有 x=0,...,10 和 y=0,...,10 的点都在里面
一个有角 (3,2)、(5,6) 和 (8,4) 的三角形
一个半径为 2.5、圆心为 (5,4) 的圆
请注意,光线转换算法也适用于更多的角(对于更多的角,角的顺序定义多边形)。
关于c++ - 计算圆、矩形和三角形坐标内的点 C++,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36023309/
#include using namespace std; class C{ private: int value; public: C(){ value = 0;
这个问题已经有答案了: What is the difference between char a[] = ?string?; and char *p = ?string?;? (8 个回答) 已关闭
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 7 年前。 此帖子已于 8 个月
除了调试之外,是否有任何针对 c、c++ 或 c# 的测试工具,其工作原理类似于将独立函数复制粘贴到某个文本框,然后在其他文本框中输入参数? 最佳答案 也许您会考虑单元测试。我推荐你谷歌测试和谷歌模拟
我想在第二台显示器中移动一个窗口 (HWND)。问题是我尝试了很多方法,例如将分辨率加倍或输入负值,但它永远无法将窗口放在我的第二台显示器上。 关于如何在 C/C++/c# 中执行此操作的任何线索 最
我正在寻找 C/C++/C## 中不同类型 DES 的现有实现。我的运行平台是Windows XP/Vista/7。 我正在尝试编写一个 C# 程序,它将使用 DES 算法进行加密和解密。我需要一些实
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
有没有办法强制将另一个 窗口置于顶部? 不是应用程序的窗口,而是另一个已经在系统上运行的窗口。 (Windows, C/C++/C#) 最佳答案 SetWindowPos(that_window_ha
假设您可以在 C/C++ 或 Csharp 之间做出选择,并且您打算在 Windows 和 Linux 服务器上运行同一服务器的多个实例,那么构建套接字服务器应用程序的最明智选择是什么? 最佳答案 如
你们能告诉我它们之间的区别吗? 顺便问一下,有什么叫C++库或C库的吗? 最佳答案 C++ 标准库 和 C 标准库 是 C++ 和 C 标准定义的库,提供给 C++ 和 C 程序使用。那是那些词的共同
下面的测试代码,我将输出信息放在注释中。我使用的是 gcc 4.8.5 和 Centos 7.2。 #include #include class C { public:
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
我的客户将使用名为 annoucement 的结构/类与客户通信。我想我会用 C++ 编写服务器。会有很多不同的类继承annoucement。我的问题是通过网络将这些类发送给客户端 我想也许我应该使用
我在 C# 中有以下函数: public Matrix ConcatDescriptors(IList> descriptors) { int cols = descriptors[0].Co
我有一个项目要编写一个函数来对某些数据执行某些操作。我可以用 C/C++ 编写代码,但我不想与雇主共享该函数的代码。相反,我只想让他有权在他自己的代码中调用该函数。是否可以?我想到了这两种方法 - 在
我使用的是编写糟糕的第 3 方 (C/C++) Api。我从托管代码(C++/CLI)中使用它。有时会出现“访问冲突错误”。这使整个应用程序崩溃。我知道我无法处理这些错误[如果指针访问非法内存位置等,
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 7 年前。
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,因为
我有一些 C 代码,将使用 P/Invoke 从 C# 调用。我正在尝试为这个 C 函数定义一个 C# 等效项。 SomeData* DoSomething(); struct SomeData {
这个问题已经有答案了: Why are these constructs using pre and post-increment undefined behavior? (14 个回答) 已关闭 6
我是一名优秀的程序员,十分优秀!