加载中…
个人资料
  • 博客等级:
  • 博客积分:
  • 博客访问:
  • 关注人气:
  • 获赠金笔:0支
  • 赠出金笔:0支
  • 荣誉徽章:
正文 字体大小:

C语言谁在说谎问题

(2018-09-18 15:16:48)
标签:

365

c语言

it

编程

教育

分类: C语言经典100例

现有张三、李四和王五3个人,张三说李四在说谎,李四说王五在说谎,而王五说张三和李四两人都在说谎。要求编程求出这3个人中到底谁说的是真话,谁说的是假话。

http://s1/mw690/0063TDLRzy7nIUvvKj6d0&690

问题分析

显然该题是一个逻辑推断问题。张三、李四和王五3个人都可能说真话,也都可能说假话,那么如何来判断他们到底谁在说谎呢?

由问题描述可得到如下3个结论:

  • 由于“张三说李四在说谎”,因此,如果张三说的是真话,则李四就在说谎;反之,如果张三在说谎,则李四说的就是真话。

  • 由于“李四说王五在说谎”,因此,如果李四说的是真话,则王五就在说谎;反之,如果李四在说谎,则王五说的就是真话。

  • 由于“王五说张三和李四两人都在说谎”,因此,如果王五说的是真话,则张三和李四两人都在说谎;反之,如果王五在说谎,则张三和李四两人至少一人说的是真话。

算法设计

该问题同样可用穷举法进行解决。

首先将问题分析中得到的3个分析结果用表达式表达出来。用变量x、y和z分别表示张三、李四和王五3人说话真假的情况,当x、y或z的值为1时表示该人说的是真话,值为0时表示该人说的是假话。则问题分析中的3个结论可以使用如下的表达式进行表示:

  • x==1 && y==0   表示张三说的是真话,李四在说谎;

  • x==0 && y==1   表示张三在说谎,李四说的是真话;

  • y==1 && z==0   表示李四说的是真话,王五在说谎;

  • y==0 && z==1   表示李四在说谎,王五说的是真话;

  • z==1 && x==0 && y==0   表示王五说的是真话,则张三和李四两人都在说谎;

  • z==0 && (x+y)!=0   表示王五在说谎,则张三和李四两人至少一人说的是真话。


在C语言中,可以使用一个逻辑表达式来表达出一个复杂的关系。将上面的表达式进行整理获得C语言的表达式如下:

(x&&!y || !x&&y) && (y&&!z || !y&&z) && (z&&x+y==0 || !z&&x+y!=0)

下面是完整的代码:


  1. #include

  2. int main()

  3. {

  4. int x, y, z;

  5. for(x=0; x<=1; x++)

  6. for(y=0; y<=1; y++)

  7. for(z=0; z<=1; z++)

  8. if( ((x&&!y) || (!x&&y)) && ((y&&!z) || (!y&&z)) && ((z&&x==0&&y==0) || (!z&&x+y!=0)) )

  9. {

  10. printf("张三说的是%s.\n",x?"真话":"假话");

  11. printf("李四说的是%s.\n",y?"真话":"假话");

  12. printf("王五说的是%s.\n",z?"真话":"假话");


  13. }

  14. return 0;

  15. }

运行结果:
张三说的是假话.
李四说的是真话.
王五说的是假话.

C/C++学习交流群:231662552,群文件有大量学习资料


0

阅读 收藏 喜欢 打印举报/Report
  

新浪BLOG意见反馈留言板 欢迎批评指正

新浪简介 | About Sina | 广告服务 | 联系我们 | 招聘信息 | 网站律师 | SINA English | 产品答疑

新浪公司 版权所有