随笔分类 -  算法导论

摘要:其实书上写很清楚了,只是写一下自己的理解备忘,没什么技术含量。拓扑排序: TOPOLOGICAL-SORT(G) 可为有向无环图产生其拓扑排序,要证明这个算法的正确性,只要证对于任意边 (u,v),有 f[v] < f[u]。因为在TOPOLOGICAL-SORT(G)算法中,总是令 f 值较大的点排在队列的前面,即“去除”(并不是真的删掉)那些 f 值较大的点。首先,当探索到 (u,v) 这条边时,v 一定不为灰色。首先,因为 u 为灰色,所以 v 一定不为灰色。再者,若 v 为白色,那么它是 u 的后续节点,有 f[v] < f[u];如果 v 是黑色的,显然有 f[v] &l 阅读全文
posted @ 2011-08-25 20:28 SunnyDay2015 阅读(936) 评论(0) 推荐(0) 编辑
摘要:FASTEST-WAY(a, t, e, x, n)1 f1[1] ← e1 + a1,12 f2[1] ←e2 + a2,13 for j ← 2 to n4 do if f1[j - 1] + a1,j ≤ f2[j - 1] + t2,j-1 + a1,j 如果想把当前任务在line1解决,则要看前一节点是在line1上还是line2上,计算二者的花费,取较小者5 then f1[j] ← f1[j - 1] + a1, j6 l1[j] ← 17 else f1[j] ← f2[j - 1] + t2,j-1 + a1,j8 l1[j] ← 29 if f2[j - 1] + a2,j 阅读全文
posted @ 2011-03-07 17:18 SunnyDay2015 阅读(260) 评论(0) 推荐(0) 编辑
摘要:In computer science, a hash table is an associative array data structure that associates keys with values. The primary operation it supports efficiently is a lookup, where it is given a key, an identifier for the information to be found such as a person's name, and asked to find the correspondin 阅读全文
posted @ 2011-02-21 20:06 SunnyDay2015 阅读(2165) 评论(0) 推荐(0) 编辑
摘要:选最大或最小值的时候可以用第一节的算法,如果既要最大值,又要最小值,那就先从输入序列中去前两个元素比较大小,将较小者与当前min比较,较大者与当前max比较,需要3次比较。 阅读全文
posted @ 2011-02-21 14:33 SunnyDay2015 阅读(232) 评论(0) 推荐(0) 编辑
摘要:BUCKET-SORT(A)1 n ← length[A]2 for i ← 1 to n3 do insert A[i] into list B[⌊n A[i]⌋]4 for i ← 0 to n - 15 do sort list B[i] with insertion sort6 concatenate the lists B[0], B[1], . . ., B[n - 1] together in order 阅读全文
posted @ 2011-02-21 14:25 SunnyDay2015 阅读(279) 评论(0) 推荐(0) 编辑
摘要:基数排序是对位数相同的一组数据进行排序的算法。主要依赖一种稳定的排序(比如计数排序)从低到高对每一个数位排序,算法复杂度为sita(d(n+k)),d是数据的位数,(n+k)是计数排序的复杂度。 阅读全文
posted @ 2011-02-21 14:20 SunnyDay2015 阅读(293) 评论(0) 推荐(0) 编辑
摘要:#include <iostream>#include <cstdlib>#include <time.h>using namespace std;//待排数据在[0,k]范围内,也可以改变上下界,不过要注意一定让//这个范围的大小大于或等于待排数据的范围,也可以把k+1理解过为//待排数据的种类数。数组下标从1开始,length是数据总量,k是数据//种类void CountingSort(int A[] , int length , int B[] , int k){ int *C = new int[k]; //初始化,将所有统计数据记为0。 for( 阅读全文
posted @ 2011-02-21 14:06 SunnyDay2015 阅读(295) 评论(0) 推荐(0) 编辑
摘要:这个定理要证明的是一比较为基础的时间复杂度的下界是O(n*lgn)。证明过程是利用n!<=l<=2^h(不是很明白为什么n!<=l,觉得二者相等),再取对数,得到h>=lg(n!)=Ω(nlgn)。 阅读全文
posted @ 2011-02-21 11:52 SunnyDay2015 阅读(336) 评论(2) 推荐(0) 编辑
摘要:#include <iostream>#include <cstdlib>using namespace std;void swap(int array[] , int i , int j){ array[i] = array[i]+array[j]; array[j] = array[i]-array[j]; array[i] = array[i]-array[j];}int Parent(int i){ if(i>1) { return i/2; } else { return 0; }}void MaxHeapify(int array[] , int i 阅读全文
posted @ 2011-02-15 16:21 SunnyDay2015 阅读(342) 评论(0) 推荐(0) 编辑
摘要:Heap-Delete(A; i)1 if i > heap-size[A]2 then error “heap underflow”3 A[i] à A[heap-size[A]]4 heap-size à heap-size-15 if A[i] > A[Parent(i)]6 then Heap-Increase-Key(A; i;A[i]) 阅读全文
posted @ 2011-02-15 16:20 SunnyDay2015 阅读(371) 评论(0) 推荐(0) 编辑
摘要:#include <iostream>using namespace std;void swap(int array[] , int i , int j){ array[i] = array[i]+array[j]; array[j] = array[i]-array[j]; array[i] = array[i]-array[j];}void MaxHeapify(int array[] , int i , int hSize){ int l = 2*i; int r = 2*i+1; int largest; while(l <= hSize) { if(array[l] 阅读全文
posted @ 2011-02-15 11:04 SunnyDay2015 阅读(441) 评论(0) 推荐(0) 编辑
摘要:MAX-HEAPIFY(A,i)函数通过递归,从元素A[i]开始与A[i]的两个子节点比较,将二者中的较大者与A[i]数值对换,如果A[i]比两个子节点数值皆大,则不执行任何操作,并向下一级继续执行MAX-HEAPIFY,即递归调用。当最后一级执行完毕时,MAX-HEAPIFY也就结束了。MAX-HEAPIFY的作用就是在执行BUILD-MAX-HEAP(A)后,将 以A[i]为子树的堆中的最大值移动到A[i]的位置,即这个子树的根节点。BUILD-MAX-HEAP(A)一定要在MAX-HEAPIFY之前执行,BUILD-MAX-HEAP(A)的作用就是从堆的倒数第二层的最后一个元素开始到堆的 阅读全文
posted @ 2011-02-14 20:47 SunnyDay2015 阅读(299) 评论(0) 推荐(0) 编辑
摘要:#include <iostream>using namespace std;void swap(int array[] , int i , int j){ /*array[i] = array[i]+array[j]; array[j] = array[i]-array[j]; array[i] = array[i]-array[j];*/ int temp; temp = array[i]; array[i] = array[j]; array[j] = temp;}void MaxHeapify(int array[] , int i , int... 阅读全文
posted @ 2011-02-14 20:40 SunnyDay2015 阅读(246) 评论(0) 推荐(0) 编辑
摘要:#include <iostream>using namespace std;void swap(int array[] , int i , int j){ /*array[i] = array[i]+array[j]; array[j] = array[i]-array[j]; array[i] = array[i]-array[j];*/ int temp; temp = array[i]; array[i] = array[j]; array[j] = temp;}void MaxHeapify(int array[] , int i , int... 阅读全文
posted @ 2011-02-14 20:37 SunnyDay2015 阅读(701) 评论(0) 推荐(0) 编辑
摘要:#include <iostream>using namespace std;void swap(int array[] , int i , int j){ /*array[i] = array[i]+array[j]; array[j] = array[i]-array[j]; array[i] = array[i]-array[j];*/ int temp; temp = array[i]; array[i] = array[j]; array[j] = temp;}void MaxHeapify(int array[] , int i , int... 阅读全文
posted @ 2011-02-14 20:37 SunnyDay2015 阅读(344) 评论(0) 推荐(0) 编辑
摘要:MAX-HEAPIFY(A,i)函数通过递归,从元素A[i]开始与A[i]的两个子节点比较,将二者中的较大者与A[i]数值对换,如果A[i]比两个子节点数值皆大,则不执行任何操作,并向下一级继续执行MAX-HEAPIFY,即递归调用。当最后一级执行完毕时,MAX-HEAPIFY也就结束了。MAX-HEAPIFY的作用就是在执行BUILD-MAX-HEAP(A)后,将 以A[i]为子树的堆中的最大值移动到A[i]的位置,即这个子树的根节点。BUILD-MAX-HEAP(A)一定要在MAX-HEAPIFY之前执行,BUILD-MAX-HEAP(A)的作用就是从堆的倒数第二层的最后一个元素开始到堆的 阅读全文
posted @ 2011-02-14 14:00 SunnyDay2015 阅读(278) 评论(0) 推荐(0) 编辑
摘要:有随机排列应聘者的步骤,则是随机算法(random algorithm),没有,则是概率分析(probability analysis)。实现随机排列的两种算法:PREMUTE-BY-SORTING(A)和RANDOM-IN-PLACE。PREMUTE-BY-SORTING算法视为每一个应聘者产生一个随机数序列,用来衡量优先级。所产生的随机数序列不出现重复的概率不小于(1-1/n),不过任然可能出现重复。RANDOM-IN-PLACE则不会有这样的问题。The birthday paradox: 用概率来推导,要注意1+x<=e^x这个不等式的作用。 在用随机变量计算概率时,最后算出数学 阅读全文
posted @ 2011-02-14 13:15 SunnyDay2015 编辑
摘要:#include <iostream>#include <cstdlib>#include <time.h>using namespace std;int random(int a , int b){ int p,m=1; //m用来保存2^p for(p=0 ; m-1<b-a ; p++) //p是二进制位数 { m *= 2; //再用m保存十进制的值 } m = rand()%2; for(int i=0 ; i<p-1 ; i++) { m = m*2+rand()%2; } if(m > b-a) { return random 阅读全文
posted @ 2011-02-14 11:25 SunnyDay2015 阅读(168) 评论(0) 推荐(0) 编辑

点击右上角即可分享
微信分享提示