我需要对指针数组所指向的数组进行排序
使用此功能(我只需要使用指针,而无需使用这些[])
void getSort(int** p2a, int arrSizes[]) //p2a is a array of pointers to diffrent arrays
我尝试了冒泡排序:
if (i < 5)
{
for (j = 1; j < arrSizes[i]; j++) // I started with 1 bcz i dont want to sort the first value
{
for (k = j + 1; k < arrSizes[i]; k++)
{
if (*(*(p2a + i) + j) > *(*(p2a + i) + k))
{
temp = *(*(p2a + i) + j);
*(*(p2a + i) + j) = *(*(p2a + i) + k);
*(*(p2a + i) + k) = temp;
}
}
i++;
}
}
但是排序不好...
例子:
之前:3 9 3 7
之后:3 3 9 7
之前:3 6 1 7
之后:3 1 6 7
之前:4 9 7 1 7
之后:4 9 7 1 7
最佳答案
更改if与for解决问题
for (i = 0; i < NUM; i++)
{
for (j = 1; j < arrSizes[i]; j++)
{
for (k = j + 1; k < arrSizes[i]; k++)
{
if (*(*(p2a + i) + j) > *(*(p2a + i) + k))
{
temp = *(*(p2a + i) + j);
*(*(p2a + i) + j) = *(*(p2a + i) + k);
*(*(p2a + i) + k) = temp;
}
}
}
}
关于c - 如何排序指针数组所指向的数组?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/36797274/