一个好玩的算法题。用java来写写

本文介绍了一个简单的Java程序,该程序通过枚举方法来验证不同身份(诚实族、撒谎族、两面族)个体的回答是否一致。通过遍历所有可能的身份组合,并检查每个人的回答与他们所属族群的行为特征是否匹配,来确定他们的实际身份。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

public class test {


/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
// 0代表身份,0代表诚实族,1代表撒谎族,2代表两面族。
int[] answerArr = new int[] { 2, 0, 1 };
/**
* answerArr对应三个人的答案,[中间的人。左边的人,右边的人] 由于答案都是围绕中间的人。所以把中间的人放在0位
*/
/**
* for循环中i代表了假设的中间的人的真实的身份
*/
int a;// 中间的人
int b;// 左边的人
int c;// 右边的人
/**
* 枚举所有情况
*/
for (int i = 0; i < 3; i++) {
a = i;
b = (i + 1) % 3;
c = (i + 2) % 3;
System.out.print(a + "," + b + "," + c);
System.out.println(":" + check(a, a == 2) + "," + check(b, a == 0)
+ "," + check(c, a == 1));
b = (i + 2) % 3;
c = (i + 1) % 3;
System.out.print(a + "," + b + "," + c);
System.out.println(":" + check(a, a == 2) + "," + check(b, a == 0)
+ "," + check(c, a == 1));
}
}


/**
* i是被检查人的身份。 answer是代表按照当前的身份他说的是真话还是假话

* @param i
* @param answer
* @return
*/
public static boolean check(int i, boolean answer) {
if (i == 0)
return answer == true ? true : false;
if (i == 1)
return answer == false ? true : false;
if (i == 2)
return true;
return false;


}


}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值