前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >编程珠玑笔记(第4章):编写正确的程序

编程珠玑笔记(第4章):编写正确的程序

作者头像
全栈程序员站长
发布2021-09-01 11:57:52
3790
发布2021-09-01 11:57:52
举报
文章被收录于专栏:全栈程序员必看

循环不变式(loop invariant):关于程序状态的断言(assertion),在每次循环迭代之前和之后都正确(循环执行过程中不一定为真)。在循环中分为以下三个阶段:

1、初始化:循环初次执行的时候不变式为真。

2、保持:如果在某处迭代开始的时候不变式为真,那么循环体执行完毕的时候仍然为真。

3、终止:循环退出的时候不变式为真。

利用数学归纳法知,1和2成立之后,3必然成立。

选择控制结构:在程序运行过程中,多个分支中的一个被执行,之前的断言以及分支的条件可以推倒出下一个断言。

迭代控制结构:在保证了循环不变式的条件下,还要满足的一个条件是:循环的终止!(二分查找的终止原因是,可能性范围在不断缩小直至为空)

契约编程:函数使用两个断言,即前置条件(precondition)和后置条件(postcondition)。

雷人瞬间:虽然第一篇二分搜索论文在1946年就发表了,但是第一个没有错误的二分搜索程序却直到1962年才出现。中间隔了16年啊!!!

转载于:https://www.cnblogs.com/jiangyoumiemie/p/3460781.html

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/109960.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档