#数据结构与算法

吴裕雄--天生自然数据结构:十大经典排序算法——归并排序

归并排序(Mergesort)是建立在归并操作上的一种有效的排序算法。该算法是采用分治法(DivideandConquer)的一个非常典型的应用。作为一种典型的分而治之思想的算法应用,归并排序的实现由两种方法:自上而下的递归(所有递归的方法都可以用迭代重写,所以就有了第2种方法);自下而上的迭代;和选择排序一样,归并排...

吴裕雄--天生自然数据结构:十大经典排序算法——希尔排序

希尔排序希尔排序,也称递减增量排序算法,是插入排序的一种更高效的改进版本。但希尔排序是非稳定排序算法。希尔排序是基于插入排序的以下两点性质而提出改进方法的:插入排序在对几乎已经排好序的数据操作时,效率高,即可以达到线性排序的效率;但插入排序一般来说是低效的,因为插入排序每次只能将数据移动一位;希尔排序的基本思想是:先将...

吴裕雄--天生自然数据结构:十大经典排序算法——插入排序

插入排序插入排序的代码实现虽然没有冒泡排序和选择排序那么简单粗暴,但它的原理应该是最容易理解的了,因为只要打过扑克牌的人都应该能够秒懂。插入排序是一种最简单直观的排序算法,它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。插入排序和冒泡排序一样,也有一种优化算法,叫做拆半插...

吴裕雄--天生自然数据结构:十大经典排序算法——选择排序

选择排序是一种简单直观的排序算法,无论什么数据进去都是O(n²)的时间复杂度。所以用到它的时候,数据规模越小越好。唯一的好处可能就是不占用额外的内存空间了吧。1.算法步骤首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置。再从剩余未排序元素中继续寻找最小(大)元素,然后放到已排序序列的末尾。重复第...

吴裕雄--天生自然数据结构:十大经典排序算法——冒泡排序

冒泡排序冒泡排序(BubbleSort)也是一种简单直观的排序算法。它重复地走访过要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来。走访数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成。这个算法的名字由来是因为越小的元素会经由交换慢慢"浮"到数列的顶端。作为最简单的排序算法之一,冒...

集合类(数据结构图、集合图、集合之间的比较)

数据结构图    集合类图     .容器中装的都是对象,因为它要把对象放到堆上面,但是1.5后就可以自动包装 map.put("one",newInteger(1)) 1.5后可以map.put("one",...

postman参数为Json数据结构

转:http://www.cnblogs.com/yangtianruo/p/5667146.html本文主要postman字段为Json结构时的操作说明本文以订单发货为例,根据接口文档去设计用户下单接口字段如图:有两种方式可以将字段Json数据传递:下图为接口字段规则: 接口为post请求方式,在postm...

java实现折半排序算法

折半插入排序法,又称二分插入排序法,是直接插入排序法的改良版,也需要执行i-1趟插入,不同之处在于,第i趟插入,先找出第i+1个元素应该插入的的位置,假定前i个数据是已经处于有序状态。折半插入排序(binaryinsertionsort)是对插入排序算法的一种改进,由于排序算法过程中,就是不断的依次将元素插入前面已排好...

Java中常用的6种排序算法详细分解

排序算法很多地方都会用到,近期又重新看了一遍算法,并自己简单地实现了一遍,特此记录下来,为以后复习留点材料。废话不多说,下面逐一看看经典的排序算法:1.选择排序选择排序的基本思想是遍历数组的过程中,以i代表当前需要排序的序号,则需要在剩余的[i…n-1]中找出其中的最小值,然后将找到的最小值与i指向的值进...

java实现归并排序算法

归并排序算法思想:分而治之(divide-conquer);每个递归过程涉及三个步骤第一,分解:把待排序的n个元素的序列分解成两个子序列,每个子序列包括n/2个元素.第二,治理:对每个子序列分别调用归并排序MergeSort,进行递归操作第三,合并:合并两个排好序的子序列,生成排序结果.?123456789101112...

java实现快速排序算法

1、算法概念。快速排序(Quicksort)是对冒泡排序的一种改进。由C.A.R.Hoare在1962年提出。2、算法思想。通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序...

JAVA简单选择排序算法原理及实现

简单选择排序:(选出最小值,放在第一位,然后第一位向后推移,如此循环)第一位与后面每一个逐个比较,每次都使最小的置顶,第一位向后推进(即刚选定的第一位是最小值,不再参与比较,比较次数减1)复杂度:所需进行记录移动的操作次数较少0--3(n-1),无论记录的初始排列如何,所需的关键字间的比较次数相同,均为n(n-1)/2...

java 合并排序算法、冒泡排序算法、选择排序算法、插入排序算法、快速排序算法的描述

算法是在有限步骤内求解某一问题所使用的一组定义明确的规则。通俗点说,就是计算机解题的过程。在这个过程中,无论是形成解题思路还是编写程序,都是在实施某种算法。前者是推理实现的算法,后者是操作实现的算法。 一个算法应该具有以下五个重要的特征: 1.有穷性:一个算法必须保证执行有限步之后结束; ...

Java经典算法汇总之冒泡排序

冒泡排序基本思想:在要排序的一组数中,对当前还未排好序的范围内的全部数,自上而下对相邻的两个数依次进行比较和调整,让较大的数往下沉,较小的往上冒。即:每当两相邻的数比较后发现它们的排序与排序要求相反时,就将它们互换。原理:比较两个相邻的元素,将值大的元素交换至右端。思路:依次比较相邻的两个数,将小数放在前面,大数放在后...

算法练习:求字符串的最长重复子串(Java实现)

1. 求字符串的最长重复子串例如:aaaaaaaaabbbbcccaaassscvvv这里面的最长重复子串为aaaaaaaaa算法思路:算法时间复杂度(O(n))1.将这一个字符串先转成char数组;2.将这一char数组进行遍历3.比较char数组中第i-1个与第i个的字符是否相等,如果不相等则进行截取字符...
首页上一页...8182838485...下一页尾页