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

资源限制

时间限制: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. spring-boot如何去获取前端传递的参数

    本文主要讨论spring-boot如何获取前端传过来的参数,这些参数主要有两大类,一类是URL里的参数,一个是请求body里的参数 url里的参数 通过url里传过来的参数一般有三种方式,下面我们来看 ...

  2. Selenium + Python + Chrome 自动化测试 环境搭建

    一.下载Python 相关的教程很多,此处不详细记录了,下面是官网下载地址: https://www.python.org/downloads/ 我使用的python版本为 Python 3.6.1 ...

  3. poi excel自动转换成javabean 支持引用类型属性二级转换

    最近项目需要使用excel导入功能,导入学生的时候需要指定所在班级,使用excel一次性导入! 将以前的代码改改支持属性内引用类的转换. 测试对象为User对象,javabean结构: private ...

  4. java -> HttpServletResponse

    HttpServletResponse HttpServletResponse概述 我们在创建Servlet时会覆盖service()方法,或doGet()/doPost(),这些方法都有两个参数,一 ...

  5. 我参与 Seata 开源项目的一些感悟

    丁老师在他的知识星球邀请我回答以下一个问题: 我觉得这个问题非常有意思,姑且把它贴到公众号这里,与大家分享一下我对这个问题的一些感悟. 感谢丁老师的邀请问答: 在这里我就简单说下,我这段时间参与 Se ...

  6. spark机器学习从0到1支持向量机SVM(五)

        分类 分类旨在将项目分为不同类别. 最常见的分类类型是二元分类,其中有两类,通常分别为正数和负数. 如果有两个以上的类别,则称为多类分类. spark.mllib支持两种线性分类方法:线性支持 ...

  7. flask之Flask-session三方组件

    from flask import Flask, views, render_template, request, session, redirect import redis as redis #p ...

  8. Excel导出到DataSet

    #region 导入excel 返回Dataset public DataSet ExecleDataSet(string filename, string file, string Type) { ...

  9. Spring 自动装配 byType

    自动装配 byType,这种模式由属性类型指定自动装配. Spring 容器看作 beans,在 XML 配置文件中 beans 的 autowire 属性设置为 byType.然后,如果它的 typ ...

  10. codeforces Gym - 101485 D Debugging (2015-2016 Northwestern European Regional Contest (NWERC 2015))

    题目描述: 点击打开链接 这题题意其实很不好理解,你有一个n行的程序,现在程序运行了r时间之后停止了运行,证明此处有一个bug,现在你需要在程序中加printf来调试找到bug所在的位置,你每次加一个 ...