摘要: 普通二叉查找树 我们知道查找二叉树有着比较好的时间复杂度, 在二叉树接近平衡的时候查找一个元素, 其时间复杂度可以达到nlog(n), 然而...如果插入的元素接近有序呢? 如图 此时这颗二叉查找树的平衡结构遭到了严重的破环, 其查找效率已经接近链表, 那么我们能不能使二叉树变得平衡呢? 当然有: 阅读全文
posted @ 2019-01-14 11:23 正月初六 阅读(535) 评论(0) 推荐(1) 编辑
摘要: 介绍几个不实用的排序算法,一来可以在学习时增加一些乐趣,放松一下自己,二来可以学习一下、思考一下这些算法失败在哪里,又是否存在一些好的地方? 睡眠排序 这是一个思想比较简单,脑洞巨大的算法 -- 我们知道sleep方法可以让一个线程睡眠s毫秒,如果需要对一个有n个数的数列进行排序,我们何不为每个数创 阅读全文
posted @ 2019-01-01 19:09 正月初六 阅读(13184) 评论(2) 推荐(3) 编辑
摘要: 计数排序引入 不难发现不论是冒泡排序还是插入排序,其排序方法都是通过对每一个数进行两两比较进行排序的,这种方法称为比较排序,实际上对每个数的两两比较严重影响了其效率,理论上比较排序时间复杂度的最低下限为nlog(n),即任何比较排序的时间复杂度将不会低于nlog(n),那么有没有方法能不经过数列比较 阅读全文
posted @ 2018-12-30 15:22 正月初六 阅读(1229) 评论(0) 推荐(2) 编辑
摘要: 冒泡排序 冒泡排序的思想是,让依次数组中相邻的数进行比较,如果前一个数比后一个数大,则两数进行交换,大的数就会象泡泡一样慢慢浮在水面上了 见图解 稳定性:稳定时间复杂度:O(n2) 动态图解 鸡尾酒排序 鸡尾酒排序是冒泡排序的改进,当算法将一个最大数冒泡到列尾时,再从列尾开始将最小值冒泡到列首 见图 阅读全文
posted @ 2018-12-25 14:01 正月初六 阅读(491) 评论(0) 推荐(1) 编辑
摘要: 上次我们了解了对数组的基本操作,那么谈到数组,我们就不得不谈谈数组的排序 什么是排序 排序是计算机内经常进行的一种操作,其目的是将一组“无序”的记录序列调整为“有序”的记录序列 -- 百度百科 排序是我们经常需要使用到的数据操作,比如最常见的对学生成绩进行排序、对商品价格进行排序以及对文件进行文件夹 阅读全文
posted @ 2018-12-25 13:56 正月初六 阅读(580) 评论(0) 推荐(0) 编辑
摘要: 插入排序 想象着你的左手拿着一手好牌[1,1,1,2,6,6,6,9,9],此时你从桌面上又抽出一张牌[1],你将抽出的牌,从又往左,依次与左手的牌进行比较(只以数字进行对比),当抽出的牌第一次不再大于手中的牌,你将抽出的牌插入此牌的相邻右边,入[1,1,1,1,2,6,6,6,9,9],绿色为从右 阅读全文
posted @ 2018-12-25 12:42 正月初六 阅读(801) 评论(0) 推荐(1) 编辑
摘要: 目录 什么是数组 数组的定义和内存分配 数组的赋值和访问 数组的注意事项 数组的内存图解 数组的插入 数组的删除 数组的扩容 数组的反转 首先 什么是数组 数组是一组地址连续、长度固定的具有相同类型的数据的集合,通过数组下标我们可以指定数字中的每一个元素 数组的定义和内存分配 在Java中通过(类型 阅读全文
posted @ 2018-10-24 10:31 正月初六 阅读(2848) 评论(0) 推荐(2) 编辑