博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
算法笔记_153:算法提高 判断名次(Java)
阅读量:6644 次
发布时间:2019-06-25

本文共 5000 字,大约阅读时间需要 16 分钟。

目录

 


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
temp = new ArrayList
(); public static ArrayList
result = new ArrayList
(); 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()); }}

 

转载地址:http://cnrvo.baihongyu.com/

你可能感兴趣的文章
2014中国民营企业500强在京津冀经济区、珠江三角洲、长江三角洲分布
查看>>
【JEECG技术博文】JEECG 简单实例解说权限控制
查看>>
如果想从jenkins直接生成docker镜像,并推送到harbor中,最简单的脚本如何实现?...
查看>>
条件随机场CRF(二) 前向后向算法评估标记序列概率
查看>>
codecombat之边远地区的森林1-11关及地牢38关代码分享
查看>>
GODOT 3.0 开发进度汇报 #6
查看>>
c#简单写售票系统
查看>>
Swift iOS tableView static cell动态计算高度
查看>>
POJ - 3164 Command Network(朱刘算法)
查看>>
phalcon:官方多模块支models层,mode数据库配置
查看>>
Java并发编程:Callable、Future和FutureTask
查看>>
【日常学习】【IDA*】codevs2449 骑士精神题解
查看>>
web.xml 配置中classpath: 与classpath*:的区别——(十一)
查看>>
tortoise svn冲突解决
查看>>
IdentityServer Topics(6)- Windows身份验证
查看>>
论操作系统对双核和多路CPU的支持
查看>>
使用Webbrowser的一点心得体会
查看>>
(筆記) 如何在Linux上使用Verilog PLI? (SOC) (Verilog PLI) (NC-Verilog) (Linux)
查看>>
五个故事说穿了很多人
查看>>
OpenGL3D图形绘制
查看>>