首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >简化逻辑语句

简化逻辑语句
EN

Stack Overflow用户
提问于 2015-12-01 05:56:55
回答 2查看 120关注 0票数 4

我有这个:

代码语言:javascript
复制
if(!A or (A and B))   //pseudocode

我想否定如果-声明:

这应该是可行的:

代码语言:javascript
复制
if(!(!A or (A and B)))  //pseudocode

但我相信有一种方法可以简化它,现在它正在逃离我。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2015-12-01 06:07:38

欢迎来到de-Morgan的布尔代数世界,然后是简单分布:

代码语言:javascript
复制
if(!(!A or (A and B)) 
=> if(!(!A) and !(A and B))
=> if(A and (!A or !B))
=> if((A and !A) or (A and !B))
=> if(A and !B) 
票数 6
EN

Stack Overflow用户

发布于 2015-12-01 06:11:43

如果你把它分解成真相表..。

代码语言:javascript
复制
A B  !A  (A and B)  A! or (A and B)
0 0  1   0          1
0 1  1   0          1
1 0  0   0          0
1 1  0   1          1

除了A and !B之外,您可以看到结果在所有情况下都是正确的,而不必知道/记住任何布尔代数规则。“除了”只是“不是”所以..。!(A and !B)...

然而,如果编写!A or (A and B)更好地适应现实世界的问题,那么就让代码保持这样吧,除非它的性能非常关键.

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/34013590

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档