06 2013 档案
【算法剖析】求字符串中无重复字符的最长字串
摘要:1、问题描述 这个问题来自leetcode中的Longest Substring Without Repeating Characters,诚如标题所述,我们需要寻找的是在一个字符串中,没有重复字符的最长字串。我们假定字符串中的字符只由$a$~$z$这26个字符构成。例如,对于字符串"$abcabcbb$",它的无重复字符最长字串是"$abc$",长度为3;对于字符串"$bbbb$",它的无重复最长字串是$b$,长度为1。2、算法一 我们能够立即想到的,最原始的算法就是,从字符串的每一个位置开始构造字串,并逐渐增大字串长度,直到碰到一
阅读全文
【算法剖析】寻找两个已序数组中的第k大元素
摘要:1、问题描述 给定两个数组A与B,其大小分别为m、n,假定它们都是已按照增序排序的数组,我们用尽可能快的方法去求两个数组合并后第k大的元素,其中,1\le k\le(m+n)。例如,对于数组A=[1,3,5,7,9],B=[2,4,6,8]。我们记第k大的数为max_{k-th},则k=4时,max_{4-th}=4。这是因为排序之后的数组A+B=[1,2,3,4,5,6,7,8,9],第4大的数是4。我们针对这一个问题进行探讨。2、算法一 第一眼看到这个题的时候,我们能够很快地想出来最基本的一种解法:对数组A和B进行合并,然后求出其第k大的数,即找到答案。合并的过程,我们可以参考归并排序..
阅读全文