问答详情
源自:6-5 数组的应用(一)

求助大神,为什么最后一个for循环,要输出arr[i]?

#include <stdio.h>

int main()

{

    double arr[]={1.78, 1.77, 1.82, 1.79, 1.85, 1.75, 1.86, 1.77, 1.81, 1.80};

    int i,j;

    printf("\n************排队前*************\n");

    for(i=0;i<10;i++)

    {

        if(i != 9)   

            printf("%.2f, ", arr[i]);  //%.2f表示小数点后精确到两位

        else

            printf("%.2f", arr[i]);    //%.2f表示小数点后精确到两位

    }

    for(i=8; i>=0; i--)

    {

        for(j=0;j<=i;j++)

        {

            if( arr[j]>arr[j+1]      )      //

当前面的数比后面的数大时

            {

                double temp;    //定义临时变量temp

                temp=arr[j]  ;   //将前面的数赋值给temp

                arr[j]=arr[j+1];              //前后之数颠倒位置

                arr[j+1]=temp;              //将较大的数放在后面    

            }                 

        }                

    }

    printf("\n************排队后*************\n");

    for(i=0;i<10;i++)

    {

        if(i != 9)   

            printf("%.2f, ", arr[i]);  //%.

2f表示小数点后精确到两位     

        else

            printf("%.2f", arr[i]);    //%.2f表示小数点后精确到两位

    }

    return 0;    

}


提问者:weixin_慕村0558235 2019-04-27 22:38

个回答

  • 精慕门8335481
    2019-05-05 22:59:47
    已采纳

    要把排好的数组输出

  • liujunjiede
    2019-05-03 22:27:38

    如果是arr[j],那么会循环输出最后一次arr[j]的值,输出arr[i] 则会输出已经替换好,按照大小顺序排列的数组arr[i]

    是这样的吧?

  • weixin_慕村0558235
    2019-04-27 22:39:01

    https://img2.mukewang.com/5cc469770001976507620657.jpg数组问题