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域中加入该宏即可。
#define DISABLE_COPY_AND_ASSIGN(type_name) \
type_name(const type_name&); \
type_name& operator=(const type_name&)
这里我把其中的两个基础算法——sorting中的“插入排序”和“快速排序”贴出来,估计一些要参加笔试和面试的朋友可能会感兴趣。

//-------------insertion sort-------------------------
template<typename T>
void insertion_sort(T a[], int n)
{
T tm;
for (int i=; i!=n; ++i) {
tm = a[i];
int k=i;
for (; k>; --k) {
if (tm >= a[k-])
break;
a[k] = a[k-];
}
a[k] = tm;
}
}
//---------------------------------------------------


//------------------quick sort----------------------
template<typename T>
T median(T a[], int left, int right)
{
int center = (left + right) / ;
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-];
a[right-] = tm;
return a[right-];
}
template<typename T>
void q_sort(T a[], int left, int right)
{
// 如果剩余未排序的数组长度太小,使用插入排序算法进行剩余数组的排序
if (left+ <= right) {
T pivot = median(a,left,right);
int i = left;
int j = right - ;
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-];
a[right-] = tm;
q_sort(a,left,i-);
q_sort(a,i+,right);
}
else
insertion_sort(a+left,right-left+);
}
template<typename T>
void quicksort(T a[], int n)
{
q_sort(a,,n-);
}
//--------------------------------------------------

下载地址:http://files.cnblogs.com/haibindev/data_structures_and_algorithms.7z
C++基础代码--20余种数据结构和算法的实现的更多相关文章
- 数据结构与算法的实现(c++)之第一天
开发工具:codeblocks 17.12版本 学习视频来自b站 第一天:学习swap交换.冒泡排序 swap交换:swap是几乎所有的排序的最基础部分,代码如下: #include <iost ...
- 小迪安全 Web安全 基础入门 - 第四天 - 30余种加密编码进制&Web&数据库&系统&代码&参数值
一.密码存储加密 1.MD5值是32或16位由数字"0-9"和字母"a-f"所组成的字符串 2.SHA1加密的密文特征与MD5类似,但位数是40位 3.NTLM ...
- Redis 02: redis基础知识 + 5种数据结构 + 基础操作命令
Redis基础知识 1).测试redis服务的性能: redis-benchmark 2).查看redis服务是否正常运行: ping 如果正常---pong 3).查看redis服务器的统计信息: ...
- Mysql基础代码(不断完善中)
Mysql基础代码,不断完善中~ /* 启动MySQL */ net start mysql /* 连接与断开服务器 */ mysql -h 地址 -P 端口 -u 用户名 -p 密码 /* 跳过权限 ...
- Redis 5种数据结构使用及注意事项
1优缺点 非常非常的快,有测评说比Memcached还快(当大家都是单CPU的时候),而且是无短板的快,读写都一般的快,所有API都差不多快,也没有MySQL Cluster.MongoDB那样更新同 ...
- 详细介绍Redis的几种数据结构以及使用注意事项(转)
原文:详细介绍Redis的几种数据结构以及使用注意事项 1. Overview 1.1 资料 <The Little Redis Book>,最好的入门小册子,可以先于一切文档之前看,免费 ...
- Lua中使用table实现的其它5种数据结构
Lua中使用table实现的其它5种数据结构 lua中的table不是一种简单的数据结构,它可以作为其他数据结构的基础,如:数组,记录,链表,队列等都可以用它来表示. 1.数组 在lua中,table ...
- Java基础-Java中23种设计模式之常用的设计模式
Java基础-Java中23种设计模式之常用的设计模式 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.设计模式分类 设计模式是针对特定场景给出的专家级的解决方案.总的来说设 ...
- Java基础-JAVA中常见的数据结构介绍
Java基础-JAVA中常见的数据结构介绍 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.什么是数据结构 答:数据结构是指数据存储的组织方式.大致上分为线性表.栈(Stack) ...
随机推荐
- HTML高级标签之表格标签
前面学习了一下HTML的经常使用标签, 今天開始高级标签之路! 一.表格标签 1.作用: 创建一张表格 2.各属性作用: <table cellspacing="0" cel ...
- Android学习之图片压缩,压缩程度高且失真度小
曾经在做手机上传图片的时候.直接获取相机拍摄的原图上传,原图大小一般1~2M.因此上传一张都比較浪费资源,有些场景还须要图片多张上传,所以近期查看了好多前辈写的关于图片处理的资料.然后试着改了一个图片 ...
- 19. Spring Boot Shiro 权限管理
转自:https://blog.csdn.net/catoop/article/details/50520958
- 1.JPA概要
转自:https://www.cnblogs.com/holbrook/archive/2012/12/30/2839842.html JPA定义了Java ORM及实体操作API的标准.本文摘录了J ...
- Python写爬虫-爬甘农大学校新闻
Python写网络爬虫(一) 关于Python: 学过C. 学过C++. 最后还是学Java来吃饭. 一直在Java的小世界里混迹. 有句话说: "Life is short, you ne ...
- JS学习笔记 - 点击、回车、ctrl+回车提交留言
疑点: oTxt1.onkeydown = function (ev) 为什么这里的onkeydown = function有变量 (ev),前面onclick函数没有? window.onload ...
- ssh远程执行命令并自动退出
usage: ssh [-1246AaCfgKkMNnqsTtVvXxYy] [-b bind_address] [-c cipher_spec] [-D [bind_address:]port] [ ...
- 快速创建SSH信任实现无密码登录
1. 生成本机的公私钥匙对[oracle@Oracle11_2 scripts]$ -t rsa Generating public/private rsa key pair. Enter file ...
- [D3] Build a Column Chart with D3 v4
Column and bar charts are staples of every visualization library. They also make a great project for ...
- 【LCS】POJ1458Common Subsequence
题目链接:http://poj.org/problem?id=1458 这是一道最长公共子序列的模板题: #include<iostream> #include<string> ...