1

我需要仅使用指针将浮点值数组排序到另一个数组中。在这个函数中,我已经将所有值输入到指针数组 p_data_start 中。排序代码是在为 p_sort_start 分配内存之后,我有两个指针指向排序数组和数据数组的顶部。内部 for 循环使用 p_data 查找 p_data_start 中的最大数,并将其分配给 p_d​​ata_pointer。在内部 for 循环之后, p_data_pointer 应该将它的值分配给 p_sort 指向的位置。存储在 p_data_pointer 指向的位置的值应该被清零,这样就不会再次检查它。

这是我的代码:

/**********************************************************************/
/* Sort values of experimental scientific data into descending order  */
/**********************************************************************/
float sort_data(int p_quantity, float *p_data_start)
{
    float *p_data,             /* Pointer that moves down the data array */
             *p_sort,         /* Pointer that moves down the sort array */
             *p_sort_start,   /* Sorted array                           */
             *p_data_pointer; /* Points to the largest number           */

    /* Allocate memory for the sorted experimental scientific data   */
    if((p_sort_start = (float*)malloc(sizeof(float) * p_quantity)) == NULL)
    {
            printf("\nCould not allocate memory for sorted array");
            printf("\nERROR NUMBER %d OCCURED", SORTING_ERROR);
            printf("\nThe program is aborting.");
            exit(SORTING_ERROR);
    }

    /* Sort the data into descending order                           */
    for(p_sort = p_sort_start; (p_sort-p_sort_start) < p_quantity;
                                                                 p_sort++)
    {
            p_data_pointer = p_data;

            for(p_data = p_data_start; (p_data-p_data_start) < p_quantity;
                                                                    p_data++)
            {
                    if (*p_data > *p_data_pointer)
                    {
                            *p_data_pointer = *p_data;
                    }
            }

            *p_sort = *p_data_pointer;
            *p_data_pointer = 0;
    }

    /* Copy the sorted data values back into the original array     */
    memcpy(p_sort_start, p_data_start, sizeof(float) * p_quantity);

    /* Free memory from the sorted array                            */
    free(p_sort_start);

    return 0;
}

当我打印出数据时,数字与输入的顺序相同,但其他一切正常。帮助将不胜感激。

4

1 回答 1

0

这里:

if (*p_data > *p_data_pointer)
{
    *p_data_pointer = *p_data;
}

你想要的确实是

if (*p_data > *p_data_pointer)
{
    p_data_pointer = p_data;
}

您只想将最大值的新地址p_data_pointer存储到而不是替换它指向的值。

于 2013-10-11T00:04:10.970 回答