2017-09-05学习记录1

今天复习了五个排序,分别是冒泡排序,选择排序,插入排序,哈希排序和快速排序;

然后看了thinking in java的第一章和第二章;

下面就是今天学的所有知识


1.冒泡排序:冒泡排序主要是对邻近的数据进行比较,根据结果判断是否进行交换,一轮一轮挑出其中比较大(小)的数据放到数组末尾;在一轮一轮比较中,需要比较的数据一次减少一个,直到最后下标为0和1的进行比较后,则代表数组已经有序了。

下面是实现代码:

冒泡排序

在这里面,upper用来决定每一轮进行排序的数据个数,由于下标可以为0且内部有sc[i+1]代码的存在,所以里层for循环的取值为:0~sc.length-2;

2.选择排序:这个选择排序和冒泡排序进行比较的次数相等,不过这里是一次性找出一轮数据中最大(小)的数据,放在数组末尾(开头),然后下一轮取其他的数据再一次进行选取最大(小)值;

下面是实现代码:

选择排序

这里实现的是一个从小到大的排序。首先upper和上面一样取值:1~sc.length-1,在表循环中,将sc[0]设置为最大值,然后数据判断从下标1开始,若有sc[n]<sc[0]则把最大值的下标由0换成n,最后判断一下最后的数据是否是下标代表的最大值,不是则把下标代表的最大值和最后面的值做一个交换,这样就完成了一次排序;

这里的子循环中的i可以为1,这代表sc[0]和sc[1]进行比较;


3.插入排序:插入排序是把一个数组分成了三个部分:有序部分,待插入值,无序部分;有序部分的个数由1~sc.length-1;当最后一个数据也进入了有序队列,则排序完成;插入排比价序主要是将待插入值放入有序队列中去,通过比较,将它插入到队列中形成一个有序的新队列;

下面是插入排序的代码:

插入排序

其中count代表待插入值的下标,1~sc.length-1;然后子循环中用num来存储待插入值,让每一个值和他比较,若待插入值小于比较的值,则把比较的值直接后移一位;i=1时代表前面所有数据都大于待插入值,所以就把该值放在0下标处;


4.哈希排序:哈希排序是一个改良版的插入排序,它主要是通过选取一定的间隔,在早期就把离正确位置很远的数据直接一次性转移过去,而不需要插入排序一样一次一次比较复制慢慢地转移过去。在大量数据中,他的速度要比插入排序好很多,而且它在数据逆行的情况下,速度比插入排序快了很多;下面是哈希排序的代码,这个我自己也不是很明白;

希尔排序

这里的num就是选取的固定间隔,num遵循一种算式,让每一个num互成质数,这样的效率是最高的;第一次排序,对下标为:num~sc.length-1的数据进行了间隔为num的数组的排序,注意这里子循环判断条件已经发生改变了;然后按公式慢慢减小num,最后直到为1时,代表数据已经排序完成;

哈希排序和插入排序最大的不同之处在于  sc[i] = sc[i-1]  和  sc[i] = sc[i-num];


5.快速排序:快速排序主要是应用了一个递归和划分的概念。划分指的是取一个值,将数组中的数据分成两部分,左边的全部小于该数据,右边的全部大于等于该数据;然后又把左边和右边两个数组用这个方法,分到最后,所有数据已经做到了有序状态了;这个排序要分成两个部分,一个是递归的部分,另一个是划分的部分;

划分部分
递归部分


这个函数采用的是直接把数组最右边的数据作为他的中间值(枢纽),然后在划分后,把枢纽放在两个部分中间,此时该数据已经存在了正确排序的位置了,然后对两边两组新数组进行排序……

在划分阶段,我们设置了一个左指针和右指针,分别判断两头的数据和枢纽的关系,若左侧存在大于枢纽的值并且右侧存在小于枢纽的值,则将两个值进行交换,然后继续判断,直到两个指针相等或擦肩而过,则代表该已经划分成功,这时候把最右端数据和右数组的第一个数据进行交换,则完成了划分的功能了。返回的是中间枢纽的下标值;


上面是今天所有的排序知识,后面还有另外两章;

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,029评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,238评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,576评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,214评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,324评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,392评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,416评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,196评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,631评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,919评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,090评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,767评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,410评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,090评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,328评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,952评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,979评论 2 351

推荐阅读更多精彩内容

  • 最近尝试使用pathForResource:ofType的方式去取Bundle里的资源发现没有取到,打印出来的路径...
    丶Destinyxl阅读 654评论 0 0
  • 关于人对事物的认知主要有三个方面 将若干简单认识组合为一个复合知识,由此产生出各种复杂的认识。 将两个认识放在一起...
    kisslight阅读 215评论 0 0
  • 前段时间辞职了,多了很多时间胡思乱想。思考的范围包括但不仅限于,宇宙洪荒混沌之光,前途渺茫有点心慌……当然子曾经曰...
    Sheepy阅读 1,015评论 5 2
  • 你小跑着追上车 回头看我一眼 头发被缠在嘴边 我还是看到了遮不住的那抹笑 于是我也放下紧蹙的眉 予你一笑 马路上我...
    酒溪阅读 237评论 0 5