排序方法 最坏时间复杂度 最好时间复杂度 平均时间复杂度
插入排序 O(n2) O(n) O(n2)
选择排序 O(n2) O(n2) O(n2)
冒泡排序 O(n2) O(n) O(n2)
快速排序 O(n2) O(nlog2n) O(nlog2n)
堆排序 O(nlog2n) O(nlog2n) O(nlog2n)
归并排序 O(nlog2n) O(nlog2n) O(nlog2n)
初赛知识点
1. 在二叉树的第i(i>=1)层最多有2^(i - 1)个结点。
2. 深度为k(k>=0)的二叉树最少有k个结点,最多有2^k-1个结点。
3. 对于任一棵非空二叉树,若其叶结点数为n0,度为2的非叶结点数为n2,则n0 = n2 +1。
//性质3证明:
首先,由节点的角度看n1+n2+n0=n,设此为(1)式;
再从边的角度看,n2下接两条边,n1下接一条边,n个节点两两相连一共需要n-1条边,可得2*n2+n1=n-1,此为(2)式;
由(1)式-(2)式,可得
n0-n2=1。
分辨率为 1600x900、16 位色的位图,存储图像信息所需的空间为( )。1600*900*2/1024
[转载]蔡勒(Zeller)公式——计算任意一天是星期几
历史上的某一天是星期几?未来的某一天是星期几?关于这个问题,有很多计算公式,其中最著名的是蔡勒 (Zeller)公式,即
W=[C/4]-2C+Y+[Y/4]+[13×(M+1)/5]+D-1,
或者是
W=Y+[Y/4]+[C/4]-2C+[26×(M+1)/10]+D-1
公式都是基于 公历 的置闰规则来考虑。 公式中的符号含义如下:
• W:星期
• C:世纪数减一 (年份前两位数)
• Y:年(年份后两位数)
• M:月(M的取值范围为3至14,即在蔡勒公式中,某年的1、2月要看作上一年的13、14月来计算,比如2003 年1月1日要看作 2002 年的13月1日来计算)
• D :日
• []:称作高斯符号,代表取整,即只要整数部份
• mod:同余这里代表括号里的答案除以7后的余数
算出来的除以7,余数是几就是星期几。如果余数是0,则为星期日。
不过,以上的公式都只适合于1582年(我国明朝万历十年)10 月15日之后的情形。罗马教皇格里高利十三世在1582年组织了一批天文学家,根据哥白尼日心说计算出来的数据,对儒略历作了修改。将1582年10月5 日到14日之间的10天宣布撤销,即10月4日之后为10月15日。若要计算的日期是在1582年10月4日或之前,其公式为
W=Y+[Y/4]+[C/4]-2C+[13×(M+1)/5]+D+3.
以2049年10月1日(100周年国庆)为例,用蔡勒(Zeller)公式进行计算,过程如下:
W=Y+[Y/4]+[C/4]-2C+[26×(M+1)/10]+D-1
=49+[49/4]+[20/4]-2×20+[26×(10+1)/10]+1-1
=49+[12.25]+5-40+[28.6]
=49+12+5-40+28
=54
54除以7余5, 即2049年10月1日(100周年国庆)是星期5。
(为了方便,这里直接把大佬的博客截图下来了,希望大佬不要介意ovo建议放大食用