划水的数据员 2022-03-07 12:11 采纳率: 100%
浏览 123
已结题

编写一个函数,把double类型数组中的数据倒序排列。

#函数中使用了指针,编写完后,输出还是没有排序,请懂得人帮我看看,谢谢!
#include <stdio.h>
#define size 5
void rank(double a,int n);
int main()
{
double a[]={2,3,4,0,8} ;
int i;
rank(a,size);
for(i=0;i<size;i++)
printf("%f ",a[i]);
return 0;
}
void rank(double *a,int n)
{
int i,j;
double t;
for(i=0;*(a+i)<*(a+n);i++){
for(j=0;*(a+j)<*(a+n-i-1);j++){
if(*(a+i)>
(a+j)){
t=*(a+i);
(a+j)=(a+i);
*(a+i)=t;
}
}
}
}

img

  • 写回答

3条回答 默认 最新

  • Mr.Winter` 优质创作者: 人工智能技术领域 2022-03-07 12:20
    关注

    改成这样就可以了

    #include <stdio.h>
    #define size 5
    void rank(double* a, int n);
    int main()
    {
        double a[] = { 2,3,4,0,8 };
        int i;
        rank(a, size);
        for (i = 0; i < size; i++)
            printf("%f ", a[i]);
        return 0;
    }
    void rank(double* a, int n)
    {
        int i, j;
        double t;
        for (i = 0; i<n; i++) {
            for (j = 0; j<n; j++) {
                if (*(a + i) > *(a + j)) {
                    t = *(a + j);
                    *(a + j) = *(a + i);
                    *(a + i) = t;
                }
            }
        }
    }
    
    

    img

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 3月15日
  • 已采纳回答 3月7日
  • 创建了问题 3月7日