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

数学太差了,完全看不懂

数学太差了,完全看不懂

提问者:斑爷K 2018-07-15 17:19

个回答

  • 慕九州5552665
    2018-07-19 12:31:59
    已采纳

    #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("%1.2f, ", arr[i]);  //%1.2f表示小数点前一位,小数点后精确到两位

            else

                printf("%1.2f", arr[i]);    //%1.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("%1.2f, ", arr[i]);  //%1.2f表示小数点前一位,小数点后精确到两位     

            else

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

        }

        return 0;    

    }


  • 胖虎爱学习
    2018-07-26 01:15:40

    前后两个for循环是可以不用if的,直接可以循环printf。     关键的是中间嵌套式2层for循环,开始j=0,里面if条件arr[0]>arr[0+1]大于小于号相当于从小还是从大开始排序。if里面的赋值自然就是数组元素的前后调换,从小到大排序  2(元素0)>1(元素1)  就把元素0赋元素1的值,temp在第一列优先赋值,在第一列的缘故temp赋的是  元素0赋元素1的值之前。   为什么用两层for呢。 一层for循环的话只能够对比前一个元素的大小。4,3,2,1就只能排序成3,2,1,4。只能吧元素0推到最后。 两层for就能够反复对比,还有把 for(j=0;j<=i;j++)里面换成j<=8结果都一样。为什么不是i=9。   因为第一轮对比就能把最大的值推到最后面。