0

我目前正在尝试使用选择排序对指针数组进行排序,但没有成功。我需要只用指针对一个 int 值数组进行排序。我已经在数组中存储了值,剩下要做的就是对这些值进行排序。

这是我的代码:

void fill_rand_ver2(int *pointer, int size)
{
int randNbr;
int *i;

for(i = pointer; i < (pointer + size); i++)
{
    randNbr = (rand()%10)+1;
    *i = randNbr;
}
}

// sort array with help of selection sort using pointer
void sort_ver2(int *pointer, int size)
{
int *i, *j, swap;

for(i = pointer; i < (pointer + size); i++)
{
    for(j = i + 1; j < (pointer + size); j++)
    {
        if(*j < *i)
        {
            swap = *i;
            *i = *j;
            *j = swap;
        }
    }
}
}

// print out both arrays using pointer
void print_values_ver2(char *string, int *pointer, int size)
{
int *i;

printf("%s", string);
printf("\n");

for(i = pointer; i < (pointer + size); i++)
{
    printf("%d,", *i);
}
printf("\n\n");
}

当我运行程序并打印数据时,输入的值没有排序并保持在同一位置。我将不胜感激任何帮助。

4

1 回答 1

1

我相信你想按值排序,而不是按地址排序,所以应该是:

void sort_ver2(int *pointer, int size)
{
    int *i, *j, swap;
    int *end = NULL;

    if(size < 2 || pointer == NULL)
        return;

    end = pointer + size - 1;

    for(i = pointer; i < end; i++)
    {
        for(j = i + 1; j <= end; j++)
        {
            if(*j < *i)
            {
                swap = *i;
                *i = *j;
                *j = swap;
            }
        }
    }
}

即使您想按地址排序,您的if语句也不正确,因为在您的代码中j总是大于i 。

编辑:添加结束变量以解决内部for循环范围不正确的问题。感谢@WhozCraig。

于 2013-10-22T10:34:13.197 回答