首页 > 代码库 > 第一课——进阶高手的大门
第一课——进阶高手的大门
理解程序的本质
程序是为了实际的问题而存在
从本质上而言,程序是解决问题的步骤描述
一小步的进阶
首先理解实际问题!
确认问题类型
– 如:数值计算,求最小值个数
确认求解的步骤
– 如:打开文件,读数据,关闭文件,计算和
问题:
如何判断求解步骤的好坏
通过下面的例子说明:
#include <stdio.h> #include <malloc.h> long sum1(int n) { long ret = 0; int* array = (int*)malloc(n * sizeof(int)); int i = 0; for(i=0; i<n; i++) { array[i] = i + 1; } for(i=0; i<n; i++) { ret += array[i]; } free(array); return ret; } long sum2(int n) { long ret = 0; int i = 0; for(i=1; i<=n; i++) { ret += i; } return ret; } long sum3(int n) { long ret = 0; if( n > 0 ) { ret = (1 + n) * n / 2; } return ret; } int main(void) { printf("%ld\n", sum1(100)); printf("%ld\n", sum2(100)); printf("%ld\n", sum3(100)); return 0; }
三个函数输出相同,可是很明显,第三个高斯公式完成地最简单,至少目前给我们的直观感受是这样的,而第一个最没有必要,第二个属于大众型的。
小结
程序是为了具体问题而存在的
程序需要围绕问题的解决进行设计
同一个问题可以有多种解决方案
如何追求程序的“性价比”?
是否有可量化的方法判别程序的好坏?
第一课——进阶高手的大门
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。