У меня есть задача отсортировать точки с тремя измерениями, а затем показать их на экране. Они разделены пробелами. Есть ли более быстрый способ, чем мой?Сортировка 3d-точек
Могу ли я каким-то образом разместить это в трехмерном массиве и выполнить какую-то функцию сортировки?
#include <iostream>
using namespace std;
int x[1001], y[1001], z[1001];
int main()
{
int t; // how many points
cin>>t;
for(int counter=0; counter<t; counter++)
{
cin>>x[counter]>>y[counter]>>z[counter];
}
//sorting
for(int i=0; i<t; i++)
{
for(int j=0; j<t; j++)
{
if(x[j]>=x[j+1])
{
int tx, ty, tz;
tx=x[j];
x[j]=x[j+1];
x[j+1]=tx;
ty=y[j];
y[j]=y[j+1];
y[j+1]=ty;
tz=z[j];
z[j]=z[j+1];
z[j+1]=tz;
}
if(x[j]==x[j+1])
{
if(y[j]>=y[j+1])
{
int ty, tz;
ty=y[j];
y[j]=y[j+1];
y[j+1]=ty;
tz=z[j];
z[j]=z[j+1];
z[j+1]=tz;
}
}
if(x[j]==x[j+1] && y[j]==y[j+1])
{
if(z[j]>=z[j+1])
{
int tz;
tz=z[j];
z[j]=z[j+1];
z[j+1]=tz;
}
}
}
}
//showing results
for(int counter=1; counter<=t; ++counter)
{
cout<<x[counter]<<" "<<y[counter]<<" "<<z[counter]<<endl;
}
}
'if (x [j] == x [j + 1])' (и то же самое в следующем тесте) может быть неверным для вашего ввода. – usr2564301