// 优化后的冒泡排序,作者:C语言技术网(www.freecplus.net)码农有道。 #include #include // 采用两层循环实现的方法。 // 参数arr是待排序数组的首地址,len是数组元素的个数。 void bubblesort1(int *arr,unsigned int len) { if (len<2) return; // 数组小于2个元素不需要排序。 int ii; // 排序的趟数的计数器。 int jj; // 每趟排序的元素位置计数器。 int itmp; // 比较两个元素大小时交换位置用到的临时变量。 int ifswap; // 每趟排序过程中是否交换过元素,0-未交换;1-有交换。 // 44,3,38,5,47,15,36,26,27,2,46,4,19,50,48 for (ii=len-1;ii>0;ii--) // 一共进行len-1趟比较。 { printf("ii=%d\n",ii); ifswap=0; // 初始化交换标志。 for (jj=0;jjarr[jj+1]) // 如果前面的元素大于后面的元素,则交换它位的位置。 { itmp=arr[jj+1]; arr[jj+1]=arr[jj]; arr[jj]=itmp; ifswap=1; // 设置交换标志。 } } if (ifswap==0) return; } } // 采用递归实现的方法。 // 参数arr是待排序数组的首地址,len是数组元素的个数。 void bubblesort2(int *arr,unsigned int len) { if (len<2) return; // 数组小于2个元素不需要排序。 printf("len=%d\n",len); int ii; // 排序的元素位置计数器。 int itmp; // 比较两个元素大小时交换位置用到的临时变量。 int ifswap=0; // 排序过程中是否交换过元素,0-未交换;1-有交换。 for (ii=0;iiarr[ii+1]) // 如果前面的元素大于后面的元素,则交换它位的位置。 { itmp=arr[ii+1]; arr[ii+1]=arr[ii]; arr[ii]=itmp; ifswap=1; // 设置交换标志。 } } if (ifswap==0) return; bubblesort2(arr,--len); } int main(int argc,char *argv[]) { int arr[]={44,3,38,5,47,15,36,26,27,2,46,4,19,50,48}; int len=sizeof(arr)/sizeof(int); bubblesort2(arr,len); // 显示排序结果。 int ii; for (ii=0;ii