#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 = 9;i >= 0;i--)
{
for(j = 0;j <= i;j++)
{
if(arr[j] >= arr[i]) //当前面的数比后面的数大时
{
double temp; //定义临时变量temp
temp = arr[i]; //将前面的数赋值给temp
arr[i] = arr[j]; //前后之数颠倒位置
arr[j] = 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 = 9;i > 0;i--) // { for(j = 0;j <= i;j++) { if(arr[j] > arr[i]) //当前面的数比后面的数大时 { double temp; //定义临时变量temp temp = arr[i]; //将前面的数赋值给temp arr[i] = arr[j]; //前后之数颠倒位置 arr[j] = temp;
还是冒泡排序 这样也可以吧