在计算机科学中,循环不变式(loop invariant,或循环不变量、循环不变条件,也有译作循环不变性),是一组在循环体内、每次迭代均保持为真的性质(表达式),通常被用来证明程序或伪码的正确性(有时但较少情况下用以证明算法的正确性)。简单说来,“循环不变式”是指在循环开始和循环中,每一次迭代时为真的性质。这意味着,一个正确的循环体,在循环结束时“循环不变式”和“循环终止条件”必须同时成立。
由于循环和递归的相通,证明带有不变式的循环的部分正确性和证明通过归纳的递归程序的正确性极其相似。
循环不变代码外提(Loop-invariant code motion)是将循环内部不受循环影响的语句或表达式移到循环体之外,和此条目提到的循环不变式无关系。
霍尔逻辑
在弗洛伊德-霍尔逻辑,[1][2]While循环的部分正确性会由下列的规则所确定:
意思是:
- while 循环不可以使得 为假 - 如果在给定条件 下循环体 body 不会使不变量 从真变成假,则 在循环之前一样为真,在循环之后也会为真。
- 只要 为真时 必会循环。若其于循环之后中止,则 当为假。
参见
参考文献
Wikiwand in your browser!
Seamless Wikipedia browsing. On steroids.
Every time you click a link to Wikipedia, Wiktionary or Wikiquote in your browser's search results, it will show the modern Wikiwand interface.
Wikiwand extension is a five stars, simple, with minimum permission required to keep your browsing private, safe and transparent.