算法提高 断案
时间限制:1.0s 内存限制:512.0MB
问题描述
公安人员审问甲、乙、丙、丁四个嫌疑犯,已确知,这四个人当中仅有一人是偷窃者,还知道这四个人的答话,要么完全诚实,要么完全说谎。在回答公安人员的问话中:
甲说:“乙没有偷,是丁偷的。”
乙说:“我没有偷,是丙偷的。”
丙说:“甲没有偷,是乙偷的。”
丁说:“我没有偷,我用的那东西是我家里的。”
请根据上述四人答话,判断谁是偷窃者。
输入格式:无输入。
输出格式:输出一个字符,表示偷窃者是谁,A表示甲,B表示乙,C表示丙,D表示丁。
/**
*
* @author 细肥尸丁
* @date 2017-2-5
*
*/
public class Main {
/**
* @param args
*/
public static void main(String[] args) {
boolean[] a = new boolean[4];// 初始化默认都为false,假设都没偷
boolean[] b = new boolean[4];
// 假设偷的人为true
for (int i = 0; i < 4; i++) {
a[i] = true;
if (i > 0) {
a[i - 1] = false;
}
b[0] = !a[1] && a[3];
b[1] = !a[1] && a[2];
b[2] = !a[0] && a[1];
b[3] = !a[3];
if (b[0] != true) {
if (!(a[1] == true && a[3] == false)) {
continue;
}
}
if (b[1] != true) {
if (!(a[1] == true && a[2] == false)) {
continue;
}
}
if (b[2] != true) {
if (!(a[0] == true && a[1] == false)) {
continue;
}
}
System.out.println((char) (i + 65));
}
}
}