Topic 01

Topic 01 recap

PrintN

打印N:

cpp 复制代码
void printN(int n) {
    for (int i = 1; i <= n; i ++) {
        printf("%d\n", i);
    }
}

void printN1(int n) {
    if (n) {
        printN1(n - 1);
        printf("%d\n", n);
    }
}
  • PrintNPrintN1打印数字一个采用循环打印,一个采用递归打印,当n的值过大时,则第二个打印会直接失败,因为递归所占用的内存超出限制

计算f(x)函数

<math xmlns="http://www.w3.org/1998/Math/MathML" display="block"> f ( x ) = 1 + x + x 2 / 2 + x 3 / 3 + . . . + x 100 / 100 f(x) = 1 + x + x^2 / 2 + x^3 /3 + ... + x^{100} /100 </math>f(x)=1+x+x2/2+x3/3+...+x100/100

c 复制代码
double f1(int n, double x) {
    double res = 1;
    for (int i = 1; i <= n ; ++i) {
        res += pow(x, i) / i;
    }
    return res;
}

double f2(int n, double x) {
    double res = 0;
    for (int i = n; i > 0; --i) {
        res = res * x + 1.0 / i;
    }
    res += 1;
    return res;
}
  • 对于时间的计算,由于程序过快,故采用运行1e7次的时间(由于单次运行时间非常短,可能无法精确测量,因此通过重复运行多次来累积时间,然后除以运行次数来得到平均单次运行时间。这种方法可以提高测量精度),然后除1e7得到平均一次运行的时间

  • 对于 f1 采用一般的方法进行计算,对于 f2 采用秦九韶方法进行计算,得出的时间前者比后者多一个数量级别


关于抽象

  • 抽象只关注问题的解决思路;

  • 不关注处理的对象,进行操作的具体细节,便于设计 广泛的解决方法 处理同样原理的问题;

  • 提高 一种思路 的 普遍适用性。

End...

相关推荐
casual~10 分钟前
第?个质数(埃氏筛算法)
数据结构·c++·算法
Elnaij22 分钟前
从C++开始的编程生活(20)——AVL树
开发语言·c++
hanbr26 分钟前
【C++ STL核心】vector:最常用的动态数组容器(第九天核心)
开发语言·c++
仰泳的熊猫1 小时前
题目2308:蓝桥杯2019年第十届省赛真题-旋转
数据结构·c++·算法·蓝桥杯
hssfscv1 小时前
力扣练习训练2(java)——二叉树的中序遍历、对称二叉树、二叉树的最大深度、买卖股票的最佳时机
java·数据结构·算法
lzksword2 小时前
C++ Builder XE OpenDialog1打开多文件并显示xls与xlsx二种格式文件
java·前端·c++
niceffking2 小时前
C++内部类的ISO约定和语法细节
开发语言·c++
不想看见4042 小时前
Search a 2D Matrix II数组--力扣101算法题解笔记
数据结构·算法
IronMurphy2 小时前
【算法二十六】108. 将有序数组转换为二叉搜索树 98. 验证二叉搜索树
数据结构·算法·leetcode
艾莉丝努力练剑3 小时前
【脉脉】AI创作者崛起:掌握核心工具,在AMA互动中共同成长
运维·服务器·c++·人工智能·安全·企业·脉脉