自顶向下,逐步求精

  有时,我们会遇到一些很复杂的问题,不知道该如何下手去解决。这篇博客将会介绍“自顶向下,逐步求精”这一方法,从而使复杂的问题简单化,方便我们去解决。
  这里写图片描述
  其实这一方法的基本思路就是将问题分解。“自顶向下”,其实就是按照一定的顺序,把一个大问题分解成很多的小问题,确保我们对这些小问题有充分的把握能够解决。而“逐步求精”,就是尽可能地将现实问题转化为逻辑空间或求解空间的问题,进而转化成简单的编程问题。
  下面,我将以洗衣机为例,尝试运用这种方法解决问题。
  这里写图片描述
  首先,我们可以把洗衣机洗衣服这一大问题分解为小问题。

(1)用户选择注水量
(2)注水, 水位计计水位
(3)浸泡, 计时器计时
(4)电机转动, 先左转后右转,计时器计时
(5)排水, 水位计计水位
(6)结束

接下来,我们要考虑用伪代码来实现。我们要定义一些相关的函数。

waterinswitch(openclose) // open 打开上水开关, close关闭
wateroutswitch(openclose) // open 打开排水开关, close关闭
getwatervolume() //返回洗衣机内部水的高度
*motorrun(direction) // 电机转动。 left左转, right右转, stop停
timecounter() // 返回当前时间计数,以秒为单位
halt(returncode) *//停机, success 成功 failure 失败

然后写出了一下的伪代码,成功用代码实现了洗衣机洗衣服这一问题。

READ 用户选择的注水量
waterinswitch(open)
REPEAT
注水
UNTIL getwatervolume()=用户选择的注水量
waterinswitch(close)
REPEAT
浸泡
UNTIL timecounter()=默认时间
WHILE (电机工作时间 > 0)
REPAET
motorrun(left)
motorrun(right)
电机工作时间 --
ENDWHILE
WHILE (getwatervolume() != 0)
wateroutswitch(open)
ENDWHILE
wateroutswitch(close)
halt(returncode)

  通过这一事例,我们应该能明白“自顶向下,逐步求精”这一方法在解决问题中给我们带来的好处了吧。
  感谢阅读!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值