麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > C > 正文

用c語言實現冒泡排序,選擇排序,快速排序

2020-01-26 16:05:42
字體:
來源:轉載
供稿:網友
代碼如下所示:
復制代碼 代碼如下:

/*
 * 冒泡排序
 */
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 (i<j && *(x+j)>t) /*在右邊的只要比基準點大仍放在右邊*/
   {
    j--; /*前移一個位置*/
   }
   if (i<j)
   {
    *(x+i) = *(x+j); /*上面的循環退出:即出現比基準點小的數,替換基準點的數*/
    i++; /*后移一個位置,并以此為基準點*/
   }
   while (i<j && *(x+i)<=t) /*在左邊的只要小于等于基準點仍放在左邊*/
   {
    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<<arr[i]<<" ";
 }
 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);
 BubbleSort(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");
}

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 亚洲综合精品 | 视频一区二区三区中文字幕 | 91av99| 激情小视频在线观看 | 免费观看欧美一级片 | 91短视频在线 | 黄色7777| 亚洲电影免费观看国语版 | 欧产日产国产精品乱噜噜 | 今井夏帆av一区二区 | 88xx成人永久免费观看 | 国产乱弄 | 色七七亚洲 | 国产色片在线观看 | 黄色aaa视频 | 色交视频| 午夜在线成人 | 久久国产一级 | 色婷婷av一区二区三区久久 | 国产在线中文 | 12av毛片| 最近高清无吗免费看 | 国产精品久久久久久一区二区三区 | 欧美a视频| 国产v综合v亚洲欧美久久 | 欧美精品一级 | 午夜精品福利在线观看 | 日韩视频高清 | 免费国产一级特黄久久 | 免费视频99| 久久国产一二三 | 主人在调教室性调教女仆游戏 | 一级黄色在线观看 | 亚洲第一精品在线 | 色视频在线 | 在线观看免费污视频 | 日本精品免费观看 | 欧美精品一区二区久久 | 2021国产精品 | 毛片视频免费观看 | 亚洲电影在线播放 |