交换排序之——冒泡排序(c/c++)

冒泡排序是很有名的排序算法,经常会被人们提到,是一种较为常见的排序方法。

顾名思义,它是将数按照一定顺序给筛选出来。假定为升序,该算法将多次访问数列,第一次将最大数放置到末尾,第二次将次大数放置到倒数第二位,依次类推,直至排序结束。它每一次都能将一个数放到排序后它应该在的最终位置,待排序数会越来越少,最终均有序。例如:

初始数列为2,4,1,6,3,5      一趟之后为 2,1,4,3,5,6      第二趟后为 1,2,3,4,56   此时数列已然有序,结束。

冒泡排序是稳定的排序算法。它和直接插入排序是常用的两种简单排序方法。

它的时间复杂度为o(n^{2}),最好情况下为o(n)。空间复杂度为o(1)。

完整代码如下:(升序)

  #include<iostream>
  #define N 20
  void bubbleSort(int* arr, int num);
  int main()
  {
	  int a[N] = { 3, 2, 4, 6, 7, 5, 18, 9, 0, 1,
		  16, 8, 20, 33, 28, 64, 19, 31, 30, 25 };
	  for (int i = 0; i < N; i++)
	  {
		  std::cout << a[i] << "  ";
	  }
	  std::cout << '\n';
	  bubbleSort(a, N);
	  for (int i = 0; i < N; i++)
	  {
		  std::cout << a[i] << "  ";
	  }
	  return 0;
  }

  void bubbleSort(int* arr, int num)
  {
	  int count, i, j,temp;//count计数变量,为避免已经有序但程序仍运行,提高效率。
	  count=1;
	  while (count)
	  {
		  j = 1;//记录待排序数的数量变化(依次减少的)
		  count = 0;
		  for (i = 0; i < num - j; ++i)
		  {
			  if (arr[i] > arr[i + 1])
			  {
				  temp = arr[i];
				  arr[i] = arr[i + 1];
				  arr[i + 1] = temp;//本质是交换
				  ++count;
			  }
		  }
		  ++j;
	  }
  }

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值