C++基础代码--20余种数据结构和算法的实现

简介: C++基础代码--20余种数据结构和算法的实现

C++基础代码--20余种数据结构和算法的实现

  过年了,闲来无事,翻阅起以前写的代码,无意间找到了大学时写的一套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域中加入该宏即可。

1 #define DISABLE_COPY_AND_ASSIGN(type_name) \
2     type_name(const type_name&); \
3     type_name& operator=(const type_name&)


  这里我把其中的两个基础算法——sorting中的“插入排序”和“快速排序”贴出来,估计一些要参加笔试和面试的朋友可能会感兴趣。

 1 //-------------insertion sort-------------------------
 2 template<typename T>
 3 void insertion_sort(T a[], int n)
 4 {
 5     T tm;
 6     for (int i=0; i!=n; ++i) {
 7         tm = a[i];
 8         int k=i;
 9         for (; k>0; --k) {
10             if (tm >= a[k-1])
11                 break;
12             a[k] = a[k-1];
13         }
14         a[k] = tm;
15     }
16 }
17 //---------------------------------------------------
 1 //------------------quick sort----------------------
 2 template<typename T>
 3 T median(T a[], int left, int right)
 4 {
 5     int center = (left + right) / 2;
 6     T tm;
 7     if (a[left] > a[center]) {
 8         tm = a[left];
 9         a[left] = a[center];
10         a[center] = tm;
11      }
12     if (a[left] > a[right]) {
13         tm = a[left];
14         a[left] = a[right];
15         a[right] = tm;
16     }
17     if (a[center] > a[right]) {
18         tm = a[center];
19         a[center] = a[right];
20         a[right] = tm;
21     }
22 
23     tm = a[center];
24     a[center] = a[right-1];
25     a[right-1] = tm;
26 
27     return a[right-1];
28 }
29 
30 template<typename T>
31 void q_sort(T a[], int left, int right)
32 {
33     // 如果剩余未排序的数组长度太小,使用插入排序算法进行剩余数组的排序
34     if (left+4 <= right) {
35         T pivot = median(a,left,right);
36         int i = left;
37         int j = right - 1;
38         while (true) {
39             while (a[++i] < a[pivot]);
40             while (a[--j] > a[pivot]);
41             if (i < j) {
42                 T tm = a[i];
43                 a[i] = a[j];
44                 a[j] = tm;
45             }
46             else
47                 break;
48         }//while
49         T tm = a[i];
50         a[i] = a[right-1];
51         a[right-1] = tm;
52 
53         q_sort(a,left,i-1);
54         q_sort(a,i+1,right);
55     }
56     else
57         insertion_sort(a+left,right-left+1);
58 }
59 
60 template<typename T>
61 void quicksort(T a[], int n)
62 {
63     q_sort(a,0,n-1);
64 }
65 //--------------------------------------------------


下载地址:https://files.cnblogs.com/haibindev/data_structures_and_algorithms.7z

目录
相关文章
|
26天前
|
存储 人工智能 算法
数据结构与算法细节篇之最短路径问题:Dijkstra和Floyd算法详细描述,java语言实现。
这篇文章详细介绍了Dijkstra和Floyd算法,这两种算法分别用于解决单源和多源最短路径问题,并且提供了Java语言的实现代码。
62 3
数据结构与算法细节篇之最短路径问题:Dijkstra和Floyd算法详细描述,java语言实现。
|
29天前
|
机器学习/深度学习 存储 缓存
数据结构与算法学习十:排序算法介绍、时间频度、时间复杂度、常用时间复杂度介绍
文章主要介绍了排序算法的分类、时间复杂度的概念和计算方法,以及常见的时间复杂度级别,并简单提及了空间复杂度。
20 1
数据结构与算法学习十:排序算法介绍、时间频度、时间复杂度、常用时间复杂度介绍
|
10天前
|
算法 测试技术 开发者
在Python开发中,性能优化和代码审查至关重要。性能优化通过改进代码结构和算法提高程序运行速度,减少资源消耗
在Python开发中,性能优化和代码审查至关重要。性能优化通过改进代码结构和算法提高程序运行速度,减少资源消耗;代码审查通过检查源代码发现潜在问题,提高代码质量和团队协作效率。本文介绍了一些实用的技巧和工具,帮助开发者提升开发效率。
14 3
|
9天前
|
分布式计算 Java 开发工具
阿里云MaxCompute-XGBoost on Spark 极限梯度提升算法的分布式训练与模型持久化oss的实现与代码浅析
本文介绍了XGBoost在MaxCompute+OSS架构下模型持久化遇到的问题及其解决方案。首先简要介绍了XGBoost的特点和应用场景,随后详细描述了客户在将XGBoost on Spark任务从HDFS迁移到OSS时遇到的异常情况。通过分析异常堆栈和源代码,发现使用的`nativeBooster.saveModel`方法不支持OSS路径,而使用`write.overwrite().save`方法则能成功保存模型。最后提供了完整的Scala代码示例、Maven配置和提交命令,帮助用户顺利迁移模型存储路径。
|
16天前
|
存储 Java 开发者
Java中的Map接口提供了一种优雅的方式来管理数据结构,使代码更加清晰、高效
【10月更文挑战第19天】在软件开发中,随着项目复杂度的增加,数据结构的组织和管理变得至关重要。Java中的Map接口提供了一种优雅的方式来管理数据结构,使代码更加清晰、高效。本文通过在线购物平台的案例,展示了Map在商品管理、用户管理和订单管理中的具体应用,帮助开发者告别混乱,提升代码质量。
25 1
|
23天前
|
存储 缓存 算法
如何通过优化算法和代码结构来提升易语言程序的执行效率?
如何通过优化算法和代码结构来提升易语言程序的执行效率?
|
22天前
|
存储 算法 Java
Set接口及其主要实现类(如HashSet、TreeSet)如何通过特定数据结构和算法确保元素唯一性
Java Set因其“无重复”特性在集合框架中独树一帜。本文解析了Set接口及其主要实现类(如HashSet、TreeSet)如何通过特定数据结构和算法确保元素唯一性,并提供了最佳实践建议,包括选择合适的Set实现类和正确实现自定义对象的hashCode()与equals()方法。
31 4
|
23天前
|
搜索推荐
插入排序算法的讲解和代码
【10月更文挑战第12天】插入排序是一种基础的排序算法,理解和掌握它对于学习其他排序算法以及数据结构都具有重要意义。你可以通过实际操作和分析,进一步深入了解插入排序的特点和应用场景,以便在实际编程中更好地运用它。
|
29天前
|
存储 算法 C++
高精度算法(加、减、乘、除,使用c++实现)
高精度算法(加、减、乘、除,使用c++实现)
333 0
高精度算法(加、减、乘、除,使用c++实现)
|
29天前
|
搜索推荐 算法
数据结构与算法学习十四:常用排序算法总结和对比
关于常用排序算法的总结和对比,包括稳定性、内排序、外排序、时间复杂度和空间复杂度等术语的解释。
17 0
数据结构与算法学习十四:常用排序算法总结和对比
下一篇
无影云桌面