C++冒泡排序
2015-11-19 16:50
344 查看
冒泡排序,说起来应该是最简单的。给出一组无序数组,用什么方法来进行排序呢。比如2、3、7、1、6这组数据,要将它按照从小到大的顺序排列起来。首先想到将第一个数A与后面的数比较如果后面的数比较大,那么这两个数的顺序是正确的。将当前A更新成后面较大的数,然后再与后面的比较。遇到比自己小的进行交换,但是不更新A。
如例:
1.第一次比较,2比3小,执行后2、3、7、1、6
2.第二次比较,3比7小,执行后2、3、7、1、6
3.第三次比较,7比1大,执行后2、3、1、7、6
4.第四次比较,7比6大,执行后2、3、1、6、7
这样一来,通过一次遍历比较成功的将最大的数冒泡到了数组尾端。
运行结果:
the result is:1 2 3 6 7
反思:
1.为什么需要用指针参数?
因为函数返回值无法为数组,所以只能设置空类型的函数,利用形参如何改变实参的值呢?指针参数就是最佳选择。
2.这种排序的效率如何?
每一个数都需要全数组遍历,所以当数组长度为N时,需要N*N次遍历操作。时间效率上位O(N^2)。但是我们使用的变量极少,只利用了一个temp保存A值,所以空间复杂度为O(1)。
如例:
1.第一次比较,2比3小,执行后2、3、7、1、6
2.第二次比较,3比7小,执行后2、3、7、1、6
3.第三次比较,7比1大,执行后2、3、1、7、6
4.第四次比较,7比6大,执行后2、3、1、6、7
这样一来,通过一次遍历比较成功的将最大的数冒泡到了数组尾端。
// // main.cpp // BubbleSort // // Created by MadMarical on 15/11/19. // Copyright (c) 2015年 com. All rights reserved. // #include <iostream> using namespace std; void bubbleSort(int* pData,int length) { int temp; for(int i = 0;i != length;++i) { for (int j = 0; j != length; ++j) { if (pData[i] < pData[j]) { temp = pData[i]; pData[i] = pData[j]; pData[j] = temp; } } } } void print(int* pData,int length) { for (int i = 0; i != length; ++ i) { cout<<pData[i]<<" "; } cout<<endl; } int main(int argc, const char * argv[]) { int pData[] = {2,3,7,1,6}; BubbleSort(pData,5); cout<<"the result is:"; print(pData,5); return 0; }
运行结果:
the result is:1 2 3 6 7
反思:
1.为什么需要用指针参数?
因为函数返回值无法为数组,所以只能设置空类型的函数,利用形参如何改变实参的值呢?指针参数就是最佳选择。
2.这种排序的效率如何?
每一个数都需要全数组遍历,所以当数组长度为N时,需要N*N次遍历操作。时间效率上位O(N^2)。但是我们使用的变量极少,只利用了一个temp保存A值,所以空间复杂度为O(1)。
相关文章推荐
- 一个优秀windows C++ 程序员该有哪些知识
- C++ Primer Plus第六版 第十二章 编程练习答案
- c++ int,float等转string
- c++ 头文件循环引用解法
- 链表的归并(无头结点,c语言)
- C语言学习笔记(17) 数组和指针分析
- C/C++ 指针做参数 堆内存分配
- C++ stringstream介绍,使用方法与例子
- C++ 09原型模式
- C语言用一维数组打印杨辉三角(原:无意中想到)
- 二叉搜索树的查询、插入与删除操作(Binary Search Tree, Search, Insert, Delete)(C++)
- 程序的内存布局
- 获得当前登录系统的用户名
- c语言实现动态顺序表
- C语言笔试面试总结(网上搜集)
- C++实现含有中文字符串逆序
- c++虚函数实现机制及内存模型
- 简单分析C语言中指针数组与数组指针的区别
- C语言中的回调
- c++中switch语句的使用问题