• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

用c语言实现冒泡排序,选择排序,快速排序

c语言 搞代码 4年前 (2022-01-06) 28次浏览 已收录 0个评论

本篇文章是对使用c语言实现冒泡排序,选择排序,快速排序的代码进行了详细的分析介绍,需要的朋友参考下

代码如下所示:

代码如下:
/*
 * 冒泡排序
 */
void BubbleSort(int arr[], int n)
{
 int temp;
 for (int i = 0; i <n – 1; i++)
 {
  for (int j = i + 1; j <n; j++)
  {
   if (arr[i] > arr[j])
   {
    temp = arr[i];
    arr[i] = arr[j];
    arr[j] = temp;
   }
  }
 }
}
/*
 * 选择排序
 */
void ChooseSort(int arr[], int n)
{
 int temp, k;
 for (int i = 0; i <n – 1; i++)
 {
  k = i;
  for (int j = i + 1; j <n; j++)
  {
   if (arr[k] > arr[j])
   {
    k = j;
   }
  }
  if (k != i)
  {
   temp = arr[i];
   arr[i] = arr[k];
   arr[k] = temp;
  }
 }
}
/*
 * 快速排序,官方原版
 */
void q_sort(int numbers[], int left, int right)
{
 int pivot, l_hold, r_hold;
 l_hold = left;
 r_hold = right;
 pivot = numbers[left];
 while (left <right)
 {
  while ((numbers[right] >= pivot) && (left <right))
  {
   right–;
  }
  if (left != right)
  {
   numbers[left] = numbers[right];
   left++;
  }
  while ((numbers[left] <= pivot) && (left <right))
  {
   left++;
  }
  if (left != right)
  {
   numbers[right] = numbers[left];
   right–;
  }
 }
 numbers[left] = pivot;
 pivot = left;
 left = l_hold;
 right = r_hold;
 if (left <pivot)
 {
  q_sort(numbers, left, pivot-1);
 }
 if (right > pivot)
 {
  q_sort(numbers, pivot+1, right);
 }
}
/*
 * 快速排序
 */
void quick_sort(int *x, int low, int high)
{
 int i, j, t;
 if (low <high) /*要排序的元素起止下标,保证小的放在左边,大的放在右边。这里以下标为low的元素为基准点*/
 {
  i = low;
  j = high;
  t = *(x+low); /*暂存基准点的数*/
  while (i<j) /*循环扫描*/
  {
   while (it) /*在右边的只要比基准点大仍放在右边*/
   {
    j–; /*前移一个位置*/
   }
   if (i<j)
   {
    *(x+i) = *(x+j); /*上面的循环退出:即出现比基准点小的数,替换基准点的数*/
    i++; /*后移一个位置,并以此为基准点*/
   }
   while (i<j && *(x+i)   {
    i++; /*后移一个位置*/
   }
   if (i<j)
   {
    *(x+j) = *(x+i); /*上面的循环退出:即出现比基准点大的数,放到右边*/
    j–; /*前移一个位置*/
   }
  }
  *(x+i) = t; /*一遍扫描完后,放到适当位置*/
  quick_sort(x,low,i-1);  /*对基准点左边的数再执行快速排序*/
  quick_sort(x,i+1,high);  /*对基准点右边的数再执行快速排序*/
 }
}
// 输出数组元素
void outArray(int arr[], int n)
{
 for(int i = 0; i <n; i++)
 {
  cout< }
 cout<<endl;
}
void main()
{
 const int N = 5;
 int arr1[N] = {4, 3, 5, 2, 1};
 int arr2[N] = {4, 3, 5, 2, 1};
 int arr3[N] = {4, 3, 5, 2, 1};
 cout<<"Before bubble sort"<<endl;
 outArray(arr1, N);
 BubbleSor来源gao@!dai!ma.com搞$$代^@码!网t(arr1, N);
 cout<<"After bubble sort"<<endl;
 outArray(arr1, N);
 cout<<"/nBefore chooose sort"<<endl;
 outArray(arr2, N);
 ChooseSort(arr2, N);
 cout<<"After chooose sort"<<endl;
 outArray(arr2, N);
 cout<<"/nBefore quick sort"<<endl;
 outArray(arr3, N);
 //q_sort(arr3,0, N – 1);
 quick_sort(arr3,0, N – 1);
 cout<<"After quick sort"<<endl;
 outArray(arr3, N);
 system(“pause”);
}

以上就是用c语言实现冒泡排序,选择排序,快速排序的详细内容,更多请关注gaodaima搞代码网其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:用c语言实现冒泡排序,选择排序,快速排序
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址