C++基础代码—20余种数据结构和算法的实现
来源:互联网 发布:c语言的未来 编辑:程序博客网 时间:2024/06/18 15:24
过年了,闲来无事,翻阅起以前写的代码,无意间找到了大学时写的一套C++工具集,主要是关于数据结构和算法、以及语言层面的工具类。过去好几年了,现在几乎已经回忆不起当年写代码时的情况,不过,通过文件头部注释里的日期,还是依稀想起了那些日子发生的一些事情,不禁感慨了一番。感概之余,随便翻阅了一下,发现当年的编程手法和现在相比,略显稚嫩,风格也相差的比较大了,明显受到当时读的一些经典C++书籍的影响。不过好在代码质量都算可以,都属于基础的语言层面以及数据结构的代码,操作指针比较小心,每个类也都有测试的样例,感觉对初学者应该会有用,于是拿到这里放出来,希望能对准备学习和正在学习C++语言编程的朋友有所裨益。
做了个表,看一下这个工具集里都有哪些C++类
基本上可以分为两大类,一种是关于数据结构和算法的(例如:RBtree,stack),另一种是关于C++语言本身层面的(例如:reference_count,Uncopyable)。这些类,可以在如今C++标准库或者其它C++库(如:boost)中找到类似的实现,实现它们的目的不是想自己造轮子,而是通过实现,来深入的理解到一些更本质的东西。很多时候,人们往往“知其然,不知其所以然”,当然,世界这么大,什么事情都想要“知其所以然”是不可能、也是不应该的,但是对于初学者而言,了解C++中常用的编程手法的本质,“知其所以然”,还是很必要的。
如果想在自己的项目中使用这些代码,有的地方还是需要注意和考虑一下的,比如Auto_ptr,它的原理仿照std::auto_ptr,当然,现在已经不推荐使用了,更应该使用std::unique_ptr或std::shared_ptr,而Uncopyable也可以通过更为方便的宏定义来实现,只需要在类定义private域中加入该宏即可。
#define DISABLE_COPY_AND_ASSIGN(type_name) \type_name(const type_name&); \type_name& operator=(const type_name&)
//-------------insertion sort-------------------------template<typename T>void insertion_sort(T a[], int n){ T tm; for (int i=0; i!=n; ++i) { tm = a[i]; int k=i; for (; k>0; --k) { if (tm >= a[k-1]) break; a[k] = a[k-1]; } a[k] = tm; }}//---------------------------------------------------
//------------------quick sort----------------------template<typename T>T median(T a[], int left, int right){ int center = (left + right) / 2; T tm; if (a[left] > a[center]) { tm = a[left]; a[left] = a[center]; a[center] = tm; } if (a[left] > a[right]) { tm = a[left]; a[left] = a[right]; a[right] = tm; } if (a[center] > a[right]) { tm = a[center]; a[center] = a[right]; a[right] = tm; } tm = a[center]; a[center] = a[right-1]; a[right-1] = tm; return a[right-1];}template<typename T>void q_sort(T a[], int left, int right){ // 如果剩余未排序的数组长度太小,使用插入排序算法进行剩余数组的排序 if (left+4 <= right) { T pivot = median(a,left,right); int i = left; int j = right - 1; while (true) { while (a[++i] < a[pivot]); while (a[--j] > a[pivot]); if (i < j) { T tm = a[i]; a[i] = a[j]; a[j] = tm; } else break; }//while T tm = a[i]; a[i] = a[right-1]; a[right-1] = tm; q_sort(a,left,i-1); q_sort(a,i+1,right); } else insertion_sort(a+left,right-left+1);}template<typename T>void quicksort(T a[], int n){ q_sort(a,0,n-1);}//--------------------------------------------------
原文链接:http://www.cnblogs.com/haibindev/archive/2012/01/27/2325818.html
- C++基础代码—20余种数据结构和算法的实现
- C++基础代码--20余种数据结构和算法的实现
- C++基础代码--20余种数据结构和算法的实现
- 常用的几种数据结构算法(续)
- party-bid的三种数据结构实现
- HashMap和几种数据结构的比较
- Python笔记——几种数据结构的实现:栈、队列及二叉树
- Python笔记——几种数据结构的实现:栈、队列及二叉树
- Python——几种数据结构的实现:栈、队列及二叉树
- Python笔记——几种数据结构的实现:栈、队列及二叉树
- Python笔记——几种数据结构的实现:栈、队列及二叉树
- 数据种数据表表结构的查询
- Tokyo Cabinet 的四种数据结构
- Tokyo Cabinet 的四种数据结构
- 常用的十种数据结构
- Tokyo Cabinet 的四种数据结构
- python的三种数据结构
- 管理资源的几种数据结构
- Android_BottomTabBar
- HR服务是大金矿,中国几千家掘金企业为啥出不了一家独角兽?
- 零食招商代理,没有销量何来利润?
- “阿里云之父”王坚:硅谷不应当成为我们的天花板 | 腾讯2017年Q3营收同比增61%
- MATLAB中plot的用法
- C++基础代码—20余种数据结构和算法的实现
- 网易2017秋招编程题:暗黑的字符串 [python]
- SparkML-note-Kmeans
- C语言常用操作符总结
- SQL Server中日期时间类型字段只取年月日
- hdu1045 Fire Net(最大匹配+建模)
- 开发者和工程师的区别?
- 唯快不破:TIME_WAIT重用与RFC1337
- git 管理多个私钥