英雄哥《零基础算法》2/100之 “数列”

文章目录

  • 设问
  • 题目
  • 题解报告
  • 知识点笔记
  • 《算法零基础100讲》
  • 参考资料

本学习笔记是根据《算法零基础100讲》进行的每讲总结,目标是采用刻意练习的方法对个人的学习和思考进行总结和归纳,方便复习和进一步深入理解和掌握内化。
每一讲的笔记内容大致分为三个部分:

  1. 设问,通过这一讲的学习应该理解什么内容?
  2. 题目,在学习完每讲内容后对题目先进行独立的思考和分析,记录下来;
  3. 题解报告,通过个人思考和学习其他优秀解题方案,记录个人认为较为优秀的解答并进行画图理解和内化吸收,并分析如何优化自己的思考;
  4. 知识点笔记,将本讲内容的知识点进行汇总和扩展,方便日后查阅复习;
  5. 解题模板,尽量将所学代码进行通用化处理。
    另外
    笔记中会尽量用图示的方式将所学内容进行可视化,方便记忆和内化,以及帮助读者进行理解。
    笔记至少会参考5篇以上的参考资料,并在文尾列出。

第二讲:数列

设问

  1. 数列在数学中有何作用?
  2. 数列有那些性质?
  3. 级数和数列的关系?
  4. 数学中有哪些重要的数列?
  5. C语言中的数列如何表示?有何作用?

题目

509. 斐波那契数
英雄哥《零基础算法》2/100之 “数列”_第1张图片
1137. 第 N 个泰波那契数
英雄哥《零基础算法》2/100之 “数列”_第2张图片
剑指 Offer 64. 求1+2+…+n
英雄哥《零基础算法》2/100之 “数列”_第3张图片
896. 单调数列
英雄哥《零基础算法》2/100之 “数列”_第4张图片

题解报告

int tribonacci(int n){
    int T[4] = {0, 1, 1, 2};
    enum {first = 0, second, curr, next};

    if (n < 4) {
        return T[n];
    }

    for (int i = 3; i <= n; ++i) {
        T[next] = T[first] + T[second] + T[curr];
        T[first] = T[second];
        T[second] = T[curr];
        T[curr] = T[next];
    }

    return T[curr];
}
int sumNums(int n){
    int A = n;
    int B = n + 1;
    int ans = 0;
    
    //当b为偶数,a*b=2a * b/2;当n为奇数,a*b=(b-1)/2 * 2a+a
    (B & 1) && (ans += A);
    A <<= 1;
    B >>= 1;

    (B & 1) && (ans += A);
    A <<= 1;
    B >>= 1;

    (B & 1) && (ans += A);
    A <<= 1;
    B >>= 1;

    (B & 1) && (ans += A);
    A <<= 1;
    B >>= 1;

    (B & 1) && (ans += A);
    A <<= 1;
    B >>= 1;

    (B & 1) && (ans += A);
    A <<= 1;
    B >>= 1;

    (B & 1) && (ans += A);
    A <<= 1;
    B >>= 1;

    (B & 1) && (ans += A);
    A <<= 1;
    B >>= 1;

    (B & 1) && (ans += A);
    A <<= 1;
    B >>= 1;

    (B & 1) && (ans += A);
    A <<= 1;
    B >>= 1;

    (B & 1) && (ans += A);
    A <<= 1;
    B >>= 1;

    (B & 1) && (ans += A);
    A <<= 1;
    B >>= 1;

    (B & 1) && (ans += A);
    A <<= 1;
    B >>= 1;

    (B & 1) && (ans += A);
    A <<= 1;
    B >>= 1;

    return ans >> 1;

}
bool isMonotonic(int* nums, int numsSize){
    if (numsSize == 1)   {
        return true;
    }

    int preDiff = nums[1] - nums[0] ? 
        ((nums[1] - nums[0])/fabs(nums[1] - nums[0])) : nums[1] - nums[0];
    int newDiff = 0;

    for (int i = 1; i < numsSize; ++i) {
        printf("%d ", preDiff);
        if (nums[i] - nums[i-1]) {
            printf("%d ", nums[i] - nums[i-1]);
            newDiff = (nums[i] - nums[i-1])/fabs(nums[i] - nums[i-1]);
        }

        if (preDiff && newDiff != preDiff) {
            printf("%d ", newDiff);
            return false;
        }

        if (preDiff == 0) {
            preDiff = newDiff;
        }
    }

    return true;
}
  1. 有已知递归公式,只需要计算特定值,可以只记录需要的数据,减少使用的空间;
  2. A 和 B 两数相乘的时候可以利用加法和位运算来模拟:将 B 二进制展开,如果 B 的二进制表示下第 ii 位为 1,那么这一位对最后结果的贡献就是 A*(1<

知识点笔记

数列是一列两个以上按顺序排列的数,所组成的序列,记为 ⟨ a k a_k ak⟩ 、 { a k a_k ak} 或 ( a k a_k ak):
⟨ a k ⟩ k = 1 n = ⟨ a 1 ,   a 2 ,   a 3 ,   ⋯   ,   a n ⟩ ⟨ a k ⟩ k = 1 n = ⟨ a 1 ,   a 2 ,   a 3 ,   ⋯   ,   a n ⟩ {\displaystyle \left\langle a_{k}\right\rangle _{k=1}^{n}=\left\langle a_{1},\,a_{2},\,a_{3},\,\cdots ,\,a_{n}\right\rangle }{\displaystyle \left\langle a_{k}\right\rangle _{k=1}^{n}=\left\langle a_{1},\,a_{2},\,a_{3},\,\cdots ,\,a_{n}\right\rangle } akk=1n=a1,a2,a3,,anakk=1n=a1,a2,a3,,an

几个重要的数列:

  • 等差数列:数列中,从第二项起,每一项与前一项的差相等。
  • 等比数列:从第2项起,每一项与前一项的比都是一个常数。
  • 斐波那契数列:首两项均是1,从第3项起,每一项均为前两项的和。
    以数学符号表示,即 a 1 = a 2 = 1 , 且 对 于 n ≥ 3 n ≥ 3 , a n = a n − 1 + a n − 2 {\displaystyle a_{1}=a_{2}=1},且对于{\displaystyle n\geq 3}n\geq 3,{\displaystyle a_{n}=a_{n-1}+a_{n-2}} a1=a2=1n3n3an=an1+an2
  • 素数数列:数列中的数据均为素数,目前找不到规律:2 ,3 ,5 ,7 ,11 ,13 ,17…………

数列通项公式的几种求解方式:

  • 数学归纳法
  • 逐差全加
  • 逐商全乘
  • 从和式求通项
  • 换元法
  • 不动点法

数组(计算机角度的数列)的作用:

  • 记录一组特殊的值,可以使用
  • 通过一定的规律计算得出想要的结果
  • 分析数列的特征
  1. 数列可以看作定义域为正整数集上的特殊函数.运用函数思想去研究数列,就是要借助于函数的单调性图象最值等知识解决相关问题,它不仅使问题简化,而且还可以加深对知识间的关系的理解.
  2. 运用方程思想,分析数列的规律,获得递推公式,可以通过方程解决数列问题.
  3. 不同的数据适用不同的场景,分类讨论思想根据问题的实际需要按一定标准将所研究的对象分成若干种不同的情况,可以使问题清晰.
  4. 数学概念都是从现实问题求解的思想方法中进行高度的抽象、提炼出来的。存在性和唯一性是数学概念中最基本、最核心的性质。
  5. 引入的每一个数学概念,首先初步学习概念、并利用概念解决简单结构的问题,形成初步的结论。之后,为研究、解决更一般或更复杂的对象,可引入相应的性质,进行求解。
    英雄哥《零基础算法》2/100之 “数列”_第5张图片

《算法零基础100讲》

该栏目是CSDN@英雄哪里出来大佬的万人千题计划第一阶段,其目标是让想要学会算法的人抱团成长,能通过这个项目稳步成长,扎扎实实掌握算法,最终用算法改变世界!

img

大佬将算法学习的路线总结如下,并分别根据五步路线总结写出了相应的教学内容,关于目前的第一阶段算法入门的详细的介绍可以看博文《万人千题:第一阶段,算法零基础抱团打卡》学习路线指引

img

100讲的学习大纲如下:

img

参考资料

此处列出除文中链接之外的参考资料

  1. 数列-维基百科
  2. 数列中的几种数学思想
  3. 数学性质的结构与应用思想——从数列极限的性质谈起
  4. 学会这几招,可以秒杀所有数字推理!
  5. 数列――找规律
  6. 数列
  7. 集合入门
  8. Leetcode官方题解-剑指 Offer 64. 求1+2+…+n

你可能感兴趣的:(万人千题学习报告,#,算法)