您的位置:首页 > 其它

自顶向下,逐步求精

2017-11-30 12:45 218 查看
作为一个C语言新手,我经常面对一个题目不知道如何下手。后来学习到了自顶向下,逐步求精的思维方式,终于这种情况得到明显的改观。

“自顶向下,逐步求精”的思维方式,其实就是你的大脑先能“机械化”,为指挥计算机“一步一步”地完成任务打下基础。具体方法就是分解任务,把超级大分为大的、中的、小的、超小的,直到能用很直接的方法解决。

我们找一个具体的题目作为例子:

在屏幕上输出如图所示的星号图形



我们要学会分层次地看这个问题,也就是说找出图形的规律

我们可以看到这张图有六行,每行有不同数目的星号。

我们也容易看出每行星数的规律。

由此,我们很容易就能找到做出这个题目的方法。

在实际解决问题的过程中,我们可以借助一个工具,就是伪代码。再次拿上面的题目举例:

i=1;

While(i<=6)

{

输出第i行;

换行

i=i+1;

}

其中,输出第i行这个问题还不够细致,需要进一步的分解:

j=1;

While(j<=2*i-1)

{

输出一个*;

j=j+1;

}

然后再把伪代码转化为代码就可以完成这个题目了。

在上述例题中,我们将输出一个“星号组成的图案”,分解为“循环输出若干行”,找出各行的规律,能够逐步细化到“输出第i行”这个任务,最终问题细化到只输出一个字符’*’。从“顶层”出发,“向下”(即编程中能直接实现的细节)考虑,“逐步”地“求精”得到达到用C++语句直接描述的程度。对复杂的问题,可能需要更多层次的分解。

其实,自顶向下,逐步求精的思维方式不只是在做题中有用,在生活中使用这种思维方式,我们会发现问题同样会变的容易解决许多。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: