试题 算法训练 谁干的好事?

资源限制

时间限制:1.0s 内存限制:256.0MB

问题描述

  ABCDE中num个人做了好事,truth个人说真话。

  A说:“我和X中有且只有一个做了好事”

  B说:“C和E中有人做了好事”

  C说:“我和D和A中有人做了好事”

  D说:“B和C都没有做好事”

  E说:“我没有做好事”

  请问有哪些人做了好事?

多组方案请一行一个输出。

输入格式

  仅一行,先是一个整数num,接着是一个A~E的字符X,最后是一个整数truth。意义见题面。

输出格式

  每行输出一组方案,方案中按 字母序 输出做好事的人的代号(A~E),不要空格隔开。

如果没有合法方案,输出一行一个0即可。

样例输入

1 E 2

样例输出

0

样例输入

2 E 2

样例输出

BD

BE

数据规模和约定

  规定,1 <= num <= 2。

  

PS:

其实就是先把我的做好事的循环,然后循环我说真话的,然后在判断是不是相等

import java.util.HashSet;
import java.util.Scanner;
import java.util.Set; public class 谁干得好事 {
static int[] goodMan = new int[5];
static int[] truths = new int[5];
static Set<String> list = new HashSet<>(); public static void main(String[] args) {
char[] inputs = new Scanner(System.in).nextLine().toCharArray(); int num = inputs[0] - '0', truth = inputs[4] - '0';
char x = inputs[2]; searchOne(0, num, truth, x); outputResult();
} private static void outputResult() {
if (list.size() == 0) {
System.out.println(0);
return;
}
for (String s : list) {
System.out.println(s);
}
} private static void searchOne(int k, int num, int truth, char x) {
if (k == num) {
searchTwo(0, truth, x);
return;
} for (int i = 0; i < 5; i++) {
if (goodMan[i] == 0) {
goodMan[i] = 1;
searchOne(k + 1, num, truth, x);
goodMan[i] = 0;
}
}
} private static void searchTwo(int k, int truth, char x) {
if (k == truth) {
if (judge(x)) {
addResult();
}
return;
} for (int i = 0; i < 5; i++) {
if (truths[i] == 0) {
truths[i] = 1;
searchTwo(k + 1, truth, x);
truths[i] = 0;
}
}
} private static void addResult() {
StringBuilder stringBuilder = new StringBuilder();
for (int i = 0; i < 5; i++) {
if (goodMan[i] == 1) {
stringBuilder.append((char) ('A' + i));
}
}
list.add(stringBuilder.toString());
} private static boolean judge(char x) {
boolean A = (goodMan[0] ^ goodMan[x - 'A']) == truths[0];
boolean B = ((goodMan[2] + goodMan[4]) >= 1) == (truths[1] == 1);
boolean C = ((goodMan[0] + goodMan[2] + goodMan[3]) >= 1) == (truths[2] == 1);
boolean D = ((goodMan[1] + goodMan[2]) == 0) == (truths[3] == 1);
boolean E = (goodMan[4] ^ truths[4]) == 1; return A && B && C && D && E;
} }

Java实现 蓝桥杯 算法训练 谁干的好事?的更多相关文章

  1. Java实现 蓝桥杯 算法训练 猴子吃包子(暴力)

    试题 算法训练 猴子吃包子 问题描述 从前,有一只吃包子很厉害的猴子,它可以吃无数个包子,但是,它吃不同的包子速度也不同:肉包每秒钟吃x个:韭菜包每秒钟吃y个:没有馅的包子每秒钟吃z个:现在有x1个肉 ...

  2. Java实现蓝桥杯 算法训练 大等于n的最小完全平方数

    试题 算法训练 大等于n的最小完全平方数 资源限制 时间限制:1.0s 内存限制:256.0MB 问题描述 输出大等于n的最小的完全平方数. 若一个数能表示成某个自然数的平方的形式,则称这个数为完全平 ...

  3. java实现 蓝桥杯 算法训练 Password Suspects

    问题描述 在年轻的时候,我们故事中的英雄--国王 Copa--他的私人数据并不是完全安全地隐蔽.对他来说是,这不可接受的.因此,他发明了一种密码,好记又难以破解.后来,他才知道这种密码是一个长度为奇数 ...

  4. Java实现 蓝桥杯 算法训练VIP 报数(暴力+数学)约瑟夫环问题

    试题 算法训练 报数 问题描述 现有n个同学站成一圈,顺时针编号1至n.从1号同学开始顺时针1/2报数,报到1的同学留在原地,报到2的同学退出圆圈,直到只剩一名同学为止.问最后剩下的同学编号. 输入格 ...

  5. Java实现蓝桥杯 算法训练 ALGO-15 旅行家的预算

    问题描述 一个旅行家想驾驶汽车以最少的费用从一个城市到另一个城市(假设出发时油箱是空的).给定两个城市之间的距离D1.汽车油箱的容量C(以升为单位).每升汽油能行驶的距离D2.出发点每升汽油价格P和沿 ...

  6. Java实现 蓝桥杯 算法训练 审美课

    算法训练 审美课 时间限制:1.0s 内存限制:256.0MB 提交此题 问题描述 <审美的历程>课上有n位学生,帅老师展示了m幅画,其中有些是梵高的作品,另外的都出自五岁小朋友之手.老师 ...

  7. Java实现 蓝桥杯 算法训练 多阶乘计算

    试题 算法训练 多阶乘计算 问题描述 我们知道,阶乘n!表示n*(n-1)(n-2)-21, 类似的,可以定义多阶乘计算,例如:5!!=531,依次可以有n!..!(k个'!',可以简单表示为n(k) ...

  8. Java实现 蓝桥杯 算法训练 找零钱

    试题 算法训练 找零钱 问题描述 有n个人正在饭堂排队买海北鸡饭.每份海北鸡饭要25元.奇怪的是,每个人手里只有一张钞票(每张钞票的面值为25.50.100元),而且饭堂阿姨一开始没有任何零钱.请问饭 ...

  9. Java实现 蓝桥杯 算法训练 第五次作业:字符串排序

    试题 算法训练 第五次作业:字符串排序 问题描述 输入一个小写字符串,按从小到大的顺序输出. 输入格式 bcaed 输出格式 abcde 顶格输出,中间没有空格 样例输入 一个满足题目要求的输入范例. ...

随机推荐

  1. OpenCV 经纬法将鱼眼图像展开

    文章目录 前言 理论部分 鱼眼展开流程 鱼眼标准坐标计算 标准坐标系与球坐标的转换 代码实现 测试效果如下图 总结 this demo on github 前言 鱼眼镜头相比传统的镜头,视角更广,采集 ...

  2. uCOS2014.1.10

    uC/OS-Ⅱ任务的结构有两种:一种是无限循环结构:另一种是只执行一次的程序结构.若采用只执行一次的程序结构,就要用任务删除函数来实现. uC/OS-Ⅱ进行任务的管理是从调用启动函数OSStart() ...

  3. 关于日常操作中sql的性能

    最近接手了一个项目.使用的数据库是sql server,但是遇到一些关于日期的查询的时候,查询结果非常慢.看了下别人的sql //sql = sql + " and CONVERT(nvar ...

  4. Netty入门一:何为Netty

    先了解java的网络编程 Netty为何支持高并发 netty是基于java的nio非阻塞通信,而原始的阻塞通信无法满足高并发.下面我们通过两幅图来简要说明 BIO: 这种模式下一个线程处理一个连接, ...

  5. Redis 6.0 多线程重磅发布!!!

    Redis 6.0在5.2号这个美好的日子里悄无声息的发布了,这次发布在IT圈犹如一颗惊雷一般,因为这是redis最大的一次改版,首次加入了多线程. 作者Antirez在RC1版本发布时在他的博客写下 ...

  6. SpringBoot2.0 @Cacheable 添加超时策略

    SpringBoot2.0 @Cacheable 添加超时策略 逻辑比较简单,废话不多说,直接进入正题: 需求:SpringBoot 利用注解使缓存支持过期时间 (同@Cacheable @Cache ...

  7. fakebook

    0x01 查看robots.txt 发现user.php.bak文件 得到源码 <?php class UserInfo { public $name = ""; publi ...

  8. Java -> 构造器(构造方法)

    构造方法 我们对封装已经有了基本的了解,接下来我们来看一个新的问题,依然以Person为例,由于Person中的属性都被private了,外界无法直接访问属性,必须对外提供相应的set和get方法.当 ...

  9. Djano之ORM多表查询操作

    # 把 model 转化为 迭代器去循环 MODEL.objects.all().iterator() # 等同于 values, values_list, 但是 only 这种方式 获取字段属性依旧 ...

  10. redis python操作

    1.基于连接池方式实现对五个数据类型操作,每种数据类型2个操作 2.基于spring-data-redis 基于jedis来实现对五种数据类型操作,每种数据类型实现两个操作,包括事务 以上为基于jav ...