#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;
}
----------------------------------------------------------------------------------------------------------------
for(i=8; i>=0; i--)
{
for(j=0;j<=i;j++)
{
是干嘛的
最初i=8是,arr[j]最开始是从arr[0]开始循环的,由于arr[0]是第一位所以上述arr[]中的第十位是arr[9],刚好循环为arr[j]=arr[8]时,arr[j+1]=arr{8+1]=arr[9]就可以是的上述的十个数都与arr[0]排序,在进行下一次循环,知道i=0时才停止,从而使得每一个书都参与排序进而使得十个数完全排好序