算法设计与分析:第一张 算法分析介绍 1.2逻辑推理之警察抓小偷

这篇博客通过一个警察抓小偷的例子介绍了如何将非数值化问题转化为计算机可解的逻辑推理问题。通过数字化嫌疑人编号,将每个人的陈述转换为逻辑表达式,找到满足条件的唯一解。代码实现中使用了C++的map数据结构进行处理。
摘要由CSDN通过智能技术生成
/*
警察抓小偷:
警察局抓了a,b,c,d四名嫌疑犯,其中只有一人是小偷。审问中:
a说:"我不是小偷"
b说:"c肯定是小偷"
c说:"小偷肯定是d"
d说:"c在冤枉人"

分析:
看似非数值化的问题,经过数字化之后,可以用计算机求解。
假设a,b,c,d分别用1,2,3,4编号。然后用x=i表示第i个编号的人是小偷
a说的话等价于: x != 1
b            : x = 3
c			 : x = 4
d			 : x != 4
转化为:4条语句的逻辑值之和为3
即((x != 1) + (x == 3) + (x == 4) + (x != 4)) == 3
枚举1,2,3,4分别进行测试即可

输入:

输出:
c
*/
/*

关键:
1 看似非数值化的问题,经过数字化之后,可以用计算机求解。
假设a,b,c,d分别用1,2,3,4编号。然后用x=i表示第i个编号的人是小偷
a说的话等价于: x != 1
b            : x = 3
c			 : x = 4
d			 : x != 4
转化为:4条语句的逻辑值之和为3
即((x != 1) + (x == 3) + (x == 4) + (x != 4)) == 3
枚举1,2,3,4分别进行测试即可

2printf("%c\n",(*numToName.find(x)).second);//注意map返回的是first和second
*/

#include <stdio.h>
#include <map>
#include <iostream>
#
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值