02 2011 档案
摘要:@echo offfor /f "delims=" %%i in ('dir/b/ad') do (ren "%%i\*.nes" "%%~ni.nes")pausehttp://zhidao.baidu.com/question/43360138.html?si=3
阅读全文
摘要:sourceforge http://sourceforge.net/java.net http://www.java.netwww.eclipse.orgwww.opensource.orgLomboz http://www.objectlearn.com/index.jsp (J2EE plugin for Eclipse)htmlArea http://sourceforge.net/projects/itools-htmlarea/ (所见即所得的在线HTML编辑器)XmlBuddy http://www.xmlbuddy.com/ (XML Editor plugin for Ecl
阅读全文
摘要: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
阅读全文
摘要:选最大或最小值的时候可以用第一节的算法,如果既要最大值,又要最小值,那就先从输入序列中去前两个元素比较大小,将较小者与当前min比较,较大者与当前max比较,需要3次比较。
阅读全文
摘要: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
阅读全文
摘要:基数排序是对位数相同的一组数据进行排序的算法。主要依赖一种稳定的排序(比如计数排序)从低到高对每一个数位排序,算法复杂度为sita(d(n+k)),d是数据的位数,(n+k)是计数排序的复杂度。
阅读全文
摘要:#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(
阅读全文
摘要:这个定理要证明的是一比较为基础的时间复杂度的下界是O(n*lgn)。证明过程是利用n!<=l<=2^h(不是很明白为什么n!<=l,觉得二者相等),再取对数,得到h>=lg(n!)=Ω(nlgn)。
阅读全文
摘要:一 问题描述 对一个较大规模的数组进行排序,分别使用冒泡,快速,和堆排序,比较这三种方法的效率.二 算法分析与设计 三种算法要比较哪一个效率更高,必须使用相同的数组进行排序,而且数组的元素个数要相当大,这样才能够看处它们执行效率的差别。要输入一个很大的数组显然不符合现实,因为工程太庞大了,所以我们用随机产生函数:rang()来产生所要的数组,虽然每次产生的数组都不一样,但是随机性更能体现出一个算法执行的好和坏。我们并不是就执行一次,而是通过多次的执行得出结论。 数组产生了以后,接下来的事情就是用每一种排序方法对产生的数组进行排序,同时记录下排序所需要的时间,我们通过所花时间的多少来比较哪个算法
阅读全文
摘要:#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
阅读全文
摘要: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])
阅读全文
摘要:#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]
阅读全文
摘要: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)的作用就是从堆的倒数第二层的最后一个元素开始到堆的
阅读全文
摘要:#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...
阅读全文
摘要:#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...
阅读全文
摘要:#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...
阅读全文
摘要: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)的作用就是从堆的倒数第二层的最后一个元素开始到堆的
阅读全文
摘要:有随机排列应聘者的步骤,则是随机算法(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这个不等式的作用。 在用随机变量计算概率时,最后算出数学
阅读全文
摘要:#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
阅读全文