A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 氕氘氚 中级黑马   /  2015-8-5 20:39  /  197 人查看  /  8 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

1.选择排序
选择排序是从a[0]开始,依次从原数组中取最小值,填入新数组中。
时间复杂度是O(n²)
  1. class SelectSort
  2. {
  3.         public void selectSort(int[] arr)
  4.         {
  5.                 for (int i = 0; i < arr.length - 1; i++)
  6.                 {
  7.                         for (int j = i + 1; j < arr.length; j++)
  8.                         {
  9.                                 if (arr[i] > arr[j])
  10.                                 {
  11.                                         int temp = arr[i];
  12.                                         arr[i] = arr[j];
  13.                                         arr[j] = temp;
  14.                                 }
  15.                         }
  16.                 }
  17.         }
  18. }
复制代码

8 个回复

倒序浏览
2.冒牌排序
冒泡排序是数组中相邻的两数进行比较,一次循环后的效果是最大值填入a[n-1]
时间复杂度也是O(n²)
  1. class BubbleSort
  2. {
  3.         public void bubbleSort(int[] arr)
  4.         {
  5.                 for (int i = 0; i < arr.length; i++)
  6.                 {
  7.                         for (int j = 0; j < arr.length - i; j++)
  8.                         {
  9.                                 if (arr[j] > arr[j + 1])
  10.                                 {
  11.                                         swap(arr, j, j + 1);
  12.                                 }
  13.                         }
  14.                 }
  15.         }

  16.         public void swap(int[] arr, int a, int b)
  17.         {
  18.                 arr[a] ^= arr[b];
  19.                 arr[b] ^= arr[a];
  20.                 arr[a] ^= arr[b];
  21.         }
  22. }
复制代码
回复 使用道具 举报
3.插入排序
插入排序是先将子数组排序,假如子数组长度为i,将第i+1个元素插入排好序的子数组中,循环插入,直到数组中的所有元素全部排序完成
  1. class InsertSort
  2. {
  3.         public void insertSort(int[] arr)
  4.         {
  5.                 for (int i = 1; i < arr.length; i++)
  6.                 {
  7.                         for (int j = 0; j < i; j++)
  8.                         {
  9.                                 if (arr[i] > arr[j])
  10.                                 {
  11.                                         swap(arr, i, j);
  12.                                 }
  13.                         }
  14.                 }
  15.         }

  16.         public void swap(int[] arr, int a, int b)
  17.         {
  18.                 arr[a] = arr[a] + arr[b];
  19.                 arr[b] = arr[a] - arr[b];
  20.                 arr[a] = arr[a] - arr[b];
  21.         }
  22. }
复制代码
回复 使用道具 举报
好人一生平安
回复 使用道具 举报
4.快速排序
快速排序采用分治法,指定一个数,比它大的放在它的右边,比它小的放在它的左边。
然后这左边和右边的这两个子数组再进行相同的操作,递归调用,直到整个数组排序完成。
时间复杂度为O(n)
  1. class QuickSort
  2. {
  3.         public void quickSort(int[] arr, int i, int j)
  4.         {
  5.                         int end = getEnd(arr, i, j);
  6.                         quickSort(arr, i, end - 1);
  7.                         quickSort(arr, end + 1 , j);
  8.         }

  9.         public int getEnd(int[] arr, int i, int j)
  10.         {
  11.                 int temp = arr[i];
  12.                 while (i < j)
  13.                 {
  14.                         while (arr[j] > temp)
  15.                         {
  16.                                 j--;
  17.                         }
  18.                         arr[i] = arr[j];

  19.                         while (arr[i] < temp)
  20.                         {
  21.                                 i++;
  22.                         }
  23.                         arr[j] = arr[i];
  24.                 }
  25.                 arr[i] = temp;
  26.                 return i;
  27.         }
  28. }
复制代码
回复 使用道具 举报
学习下,膜拜大水牛{:2_32:}
回复 使用道具 举报
hufan小步调 来自手机 中级黑马 2015-8-5 22:29:03
7#
后面两个没学
回复 使用道具 举报
学习了,膜拜大牛
回复 使用道具 举报
风华正茂 来自手机 中级黑马 2015-8-5 23:00:50
9#
学习了,楼主辛苦了
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马