如粗迅果A参加比赛,那么B、C、D也将参加比赛。如果上述断定为真,那么下述哪项断定
必定为真()
A.如果A没参加比赛,那么B、C、D都参加比赛
B.如果B、C、D都参加比赛,那么A也参加比赛
C.如果D没参加比赛,那么B、C不会都参加比赛
D.如果C没参加比赛,那么A、D不会都参加比赛
程序的原理是枚举所衡凳启有合理情况。一旦有某个选项在某个情况下为假,就打出false。
实践证明,只有D没有被打出。也就是满足所有情况的。为全真式。
记得第一次看到用程序来解决逻辑问题,
还是那本讲QB的教材,举了几个基本的例子。
看了觉得很搞笑的,
首先,这么简单的东西还写个程序干嘛。
其次,一直没细致地想过,只是直观上觉得构造逻辑式子很容易。
比如,A为1,B为1:
A&B
A和B至少有一个为真:
A|B
还能举出很多,让人觉得很简单的式子。
归结了一下,这类咐如式子用到的都是基本的逻辑描述:
与,或,非,异或。。。等等
而这些东西,中学的数序会提到,概率的前几章也会再讲,数字电路也会涉及。
所以,一看就觉得很眼熟,很快就构造出来了。
而原题中全部都是“XXX,那么YYY的形式”,
如果没有蕴含这个概念,就会感觉在转化上困难。
因为那几个选项在我们读来就像是一个句子。
到程序里面就有点:
IF ... THEN ...
的这种感觉。
而知道了蕴含这个概念后,可以把他们整体作为一个式子来考虑。
p蕴含q:p->q。
对应的文字描述就是“如果p,那么q”
蕴含关系的典型转换:
p->q ==>(~p)|q
也就是上面程序里面大量出现的结构。
比如来翻译这句话:
如果D没参加比赛,那么B、C不会都参加比赛
==>
D没参加比赛->B、C不会都参加比赛
B、C不会都参加比赛
==>
~(B&C)
D没参加比赛
==>
~D
那么整合起来,运用蕴含的转化式:
D|~(B&C)
也就是说“如果D没参加比赛,那么B、C不会都参加比赛"
这句话和D|~(B&C)是等价的。
static void Test(){
int time_01
bool kaiguan
int cishu = 5
__ag:
time_01 = 10
kaiguan = false
while (time_01-- >0)
{
//your code here..
/旅饥/Console.WriteLine("[{0}] -- {1}", cishu, time_01)
}
kaiguan = true
if (cishu-- >1)
{
//wait event...
goto __ag
}
//done...
}
不知道你想干氏镇衫歼腔啥。。。
C语言逻辑或与非用于逻辑运算,可以在一条语句中同时出现,但还有优先级的限制。
基本应用:
逻辑与,符号为“&&”,只有两个 *** 作数都是真,结果才是真。逻辑或,是逻辑运算符,符号是“||”。表示当两个条件中有任一个条件满足,“逻辑或”的运算结果就为“真”。“!”(逻辑非)逻辑运算符。“逻辑非”就是指本来值的反值。
优先级:
C语言中,运算符的运算优先级共分为15 级。1 级最高,15 级最低。逻辑与运算符 13级“&&”逻辑与运算符。逻辑或运算符 14 级,“ || ”逻辑或运算符。逻辑否“!”单目/一元运算 3级。因此优先激槐睁级为:逻辑非高于逻辑与高于逻辑非。
运算方向:
在C语言中,只有4个运算符规定了运算方向,它们是&&、| |、条件运算符及赋值运算符。&&、| |都是先计算左边表达式的值,当左边表达式的值能确定整个表达式的值时,就不再计算右边表达式的值。如 a = 0 &&b&&运算符的左边位0,则右边表达式b就不明厅再判断。
扩展资料:
相关规则及应用:
1、逻辑运算符:a=1,b=1;a||b-1因为a=1为真值,所以不管b-1是不是真值,总的表达式一定为真值,这时后面的表达式就不会再计算了。
2、短路原则:
在逻辑表达式的求解过程中,任何时候只要逻辑表达式的值已经可以确定,则求解过程不再进行,求解结束。表达式中优先级最低的逻辑运算符,以这些运算符为准将整个逻辑表达式分为几个计算部分。最左边一个计算部分开始,按照算术运算、关系运算和逻辑运算的规则计算该部分的值。
每计算完一个部分就与该部分右边紧靠着的逻辑运算符根据真值表进行逻辑值判断。如果已经能够判断出整个逻辑表达式的值则停止其后的所有计算;只有当整个逻辑表达式的值还不能确定的情况下才进行下一个计算部分的计算。
参考资料来源:百度百科明岁-逻辑与
参考资料来源:百度百科-逻辑或
参考资料来源:百度百科-逻辑非
参考资料来源:百度百科-C语言运算符
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)