目录

1 问题描述

2 解决方案

 


1 问题描述

问题描述
  某场比赛过后,你想要知道A~E五个人的排名是什么,于是要求他们每个人说了一句话。(经典的开头……-_-!)得了第1名的人23,说了假话;得了第5名的人不好意思,也说了假话;为了使求解问题简单,第3名同样说了假话。(奇数名次说假话)
输入格式
  共5行,各行依次表示A~E说的话。
  每行包含一个形如“A>=3”的名次判断,即一个大写字母+关系运算符+一个数字,不包含空格。
  大写字母A~E,关系运算<、<=、=、>=、>、!=,数字1~5。注意:等于是“=”不是“==”!
输出格式
  可能有多解,请按照字典序输出排名序列,每个解一行
  最后一行输出解的数量
样例输入
A=2
D=5
E>3
A>2
B!=1
样例输出
ACDEB
AECBD
BADCE
BCADE
BDACE
CEADB
CEBDA
7
 

2 解决方案

具体代码如下:

import java.util.ArrayList;
import java.util.Collections;
import java.util.Scanner; public class Main {
public static String[] say = new String[5];
public static ArrayList<String> temp = new ArrayList<String>();
public static ArrayList<String> result = new ArrayList<String>(); public void swap(char[] A, int i, int j) {
char s = A[i];
A[i] = A[j];
A[j] = s;
} public void dfs(char[] A, int step) {
if(step == A.length) {
StringBuilder s = new StringBuilder("");
for(int i = 0;i < A.length;i++)
s.append(A[i]);
temp.add(s.toString());
} else {
for(int i = step;i < A.length;i++) {
swap(A, i, step);
dfs(A, step + 1);
swap(A, i, step);
}
}
} public boolean judge(int a, String o, int p, int b) {
if(b == 1) { //此次说话为真
if(o.equals(">")) {
if(a > p)
return true;
else
return false;
} else if(o.equals(">=")) {
if(a >= p)
return true;
else
return false;
} else if(o.equals("=")) {
if(a == p)
return true;
else
return false;
} else if(o.equals("!=")) {
if(a != p)
return true;
else
return false;
} else if(o.equals("<")) {
if(a < p)
return true;
else
return false;
} else if(o.equals("<=")) {
if(a <= p)
return true;
else
return false;
}
} else if(b == 0) { //此次说话为假
if(o.equals(">")) {
if(a <= p)
return true;
else
return false;
} else if(o.equals(">=")) {
if(a < p)
return true;
else
return false;
} else if(o.equals("=")) {
if(a != p)
return true;
else
return false;
} else if(o.equals("!=")) {
if(a == p)
return true;
else
return false;
} else if(o.equals("<")) {
if(a >= p)
return true;
else
return false;
} else if(o.equals("<=")) {
if(a > p)
return true;
else
return false;
}
}
return false;
} public void getResult(int i, int j) {
for(int t = 0;t < temp.size();t++) {
String s = temp.get(t);
boolean judge1 = true;
for(int m = 0;m < 5;m++) {
char a = say[m].charAt(0);
String o = "";
int p = say[m].charAt(say[m].length() - 1) - '0';
if(say[m].length() == 3) {
o = o + say[m].substring(1, 2);
} else {
o = o + say[m].substring(1, 3);
}
if(i == m || j == m) {
judge1 = judge(s.indexOf(a) + 1, o, p, 1);
} else {
judge1 = judge(s.indexOf(a) + 1, o, p, 0);
}
if(judge1 == false)
break;
}
if(judge1 == false)
continue;
int a1 = s.indexOf(('A'+i));
int a2 = s.indexOf(('A'+j));
if((a1 == 1 && a2 == 3) || (a1 == 3 && a2 == 1)) {
judge1 = true;
} else {
judge1 = false;
} if(judge1 == true) {
if(!result.contains(s))
result.add(s);
}
}
} public static void main(String[] args) {
Main test = new Main();
String A = "ABCDE";
char[] B = A.toCharArray();
test.dfs(B, 0);
Scanner in = new Scanner(System.in);
for(int i = 0;i < 5;i++)
say[i] = in.next();
for(int i = 0;i < 5;i++) {
for(int j = i + 1;j < 5;j++)
test.getResult(i, j);
}
Collections.sort(result);
for(int i = 0;i < result.size();i++)
System.out.println(result.get(i));
System.out.println(result.size());
}
}

算法笔记_153:算法提高 判断名次(Java)的更多相关文章

  1. 算法笔记_030:回文判断(Java)

    目录 1 问题描述 2 解决方案   1 问题描述 给定一个字符串,如何判断这个字符串是否是回文串? 所谓回文串,是指正读和反读都一样的字符串,如madam.我爱我等. 2 解决方案 解决上述问题,有 ...

  2. 算法笔记_147:有向图欧拉回路判断应用(Java)

    目录 1 问题描述 2 解决方案   1 问题描述 Description In order to make their sons brave, Jiajia and Wind take them t ...

  3. Java实现 蓝桥杯 算法提高 判断名次

    算法提高 判断名次 时间限制:1.0s 内存限制:256.0MB 问题描述 某场比赛过后,你想要知道A~E五个人的排名是什么,于是要求他们每个人说了一句话.(经典的开头---_-!)得了第1名的人23 ...

  4. 算法笔记_165:算法提高 道路和航路(Java)

    目录 1 问题描述 2解决方案   1 问题描述 问题描述 农夫约翰正在针对一个新区域的牛奶配送合同进行研究.他打算分发牛奶到T个城镇(标号为1..T),这些城镇通过R条标号为(1..R)的道路和P条 ...

  5. 算法笔记_155:算法提高 概率计算(Java)

    目录 1 问题描述 2 解决方案   1 问题描述 问题描述 生成n个∈[a,b]的随机整数,输出它们的和为x的概率. 输入格式 一行输入四个整数依次为n,a,b,x,用空格分隔. 输出格式 输出一行 ...

  6. 算法笔记_166:算法提高 金属采集(Java)

    目录 1 问题描述 2 解决方案   1 问题描述 问题描述 人类在火星上发现了一种新的金属!这些金属分布在一些奇怪的地方,不妨叫它节点好了.一些节点之间有道路相连,所有的节点和道路形成了一棵树.一共 ...

  7. 算法笔记_163:算法提高 最大乘积(Java)

    目录 1 问题描述 2 解决方案   1 问题描述 问题描述 对于n个数,从中取出m个数,如何取使得这m个数的乘积最大呢? 输入格式 第一行一个数表示数据组数 每组输入数据共2行: 第1行给出总共的数 ...

  8. 算法笔记_167:算法提高 矩阵翻转(Java)

    目录 1 问题描述 2 解决方案   1 问题描述 问题描述 Ciel有一个N*N的矩阵,每个格子里都有一个整数. N是一个奇数,设X = (N+1)/2.Ciel每次都可以做这样的一次操作:他从矩阵 ...

  9. 算法笔记_164:算法提高 最小方差生成树(Java)

    目录 1 问题描述 2 解决方案   1 问题描述 问题描述 给定带权无向图,求出一颗方差最小的生成树. 输入格式 输入多组测试数据.第一行为N,M,依次是点数和边数.接下来M行,每行三个整数U,V, ...

随机推荐

  1. codevs 1044 拦截导弹 1999年NOIP全国联赛提高组

    1044 拦截导弹 1999年NOIP全国联赛提高组  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 黄金 Gold 题解       题目描述 Description 某国为 ...

  2. [APIO2007]风铃 --- 贪心

    [APIO2007]风铃 题目描述 你准备给弟弟 Ike 买一件礼物,但是,Ike 挑选礼物的方式很特别:他只喜欢那些能被他排成有序形状的东西. 你准备给 Ike 买一个风铃.风铃是一种多层的装饰品, ...

  3. loj2576 「TJOI2018」str

    link 题意: 给一个模板串s和n个模式串,每个模式串有$a_i$种可取的串.现在要将n个模式串每个任取一种它可取的串,连接起来,记为串t,那么这种连接方式对答案的贡献为t在s中出现的次数.问所有连 ...

  4. [CodeForces-178F]Representative Sampling

    题目大意: 给你n个字符串,要求从中选出k个字符串,使得字符串两两lcp之和最大. 思路: 动态规划. 首先将所有的字符串排序,求出相邻两个字符串的lcp长度(很显然,对于某一个字符串,和它lcp最长 ...

  5. WampServer -- “You don't have permission to access /phpmyadmin/ on this server.”

    当你安装完成wamp后,打开localhost或ip时发现已经可以运行了 但想使用phpmyadmin时,发现提示如下内容: You don't have permission to access / ...

  6. HDU 5296 Annoying problem dfs序 lca

    Annoying problem 题目连接: http://acm.hdu.edu.cn/showproblem.php?pid=5296 Description Coco has a tree, w ...

  7. php 安装 Redis 扩展

    开发环境安装包为:wamp3.1.0,安装成功后 wamp/bin 目录下有php以下几个版本: 这里以php7.1.9为例进行redis扩展安装,其他php版本也是一样的. 进行安装 step 1: ...

  8. 模板引擎之hogan.js

    hogan.js 语法简单,且支持循环数据: 基本语法: 1. 标签可以嵌套使用 2. {{data}} 转义的变量,不会渲染html标签 3. {{{data}}} 不转义的变量,会渲染html标签 ...

  9. [转]MinGW编译wxWidgets问题

    其实利用MinGW编译wxWidgets是一件挺简单的事情,但是最近在编译的时候遇到一些问题,并找到解决方案,因此在此分享一下个人经验.编译出错的原因是由于安装了MSYS的缘故.   错误信息类似于如 ...

  10. oc(object-c)知识汇总/总结/区别对比(持续更新)

    1.判断某个类是否实现了某方法: A *a =[[A alloc] autorelease]; if([a respondsToSelector:@selector(methodName)]){ // ...