Java的多路分支代码,感觉有点意思

作者: 沐风之境
/**
 * @Author hty
 * @Date 2019-12-16 16:39
 * @Version 1.0
 */
import java.util.Random;

// 比赛结果
enum OutCom {
    WIN,
    LOSE,
    DRAW,
}

enum RoShaBo {
    PAPER(OutCom.DRAW, OutCom.LOSE, OutCom.WIN),
    SCISSORS(OutCom.WIN, OutCom.DRAW, OutCom.LOSE),
    ROCK(OutCom.LOSE, OutCom.WIN, OutCom.DRAW);

    public OutCom withPaper;
    public OutCom withScissors;
    public OutCom withRock;

    RoShaBo(OutCom withPaper, OutCom withScissors, OutCom withRock) {
        this.withPaper = withPaper;
        this.withScissors = withScissors;
        this.withRock = withRock;
    }

    public OutCom compet(RoShaBo item) {
        switch(item){
            case PAPER:
                return withPaper;
            case SCISSORS:
                return withScissors;
            case ROCK:
                return withRock;
            default:
                return  null;
        }
    }
}

class RoShaBoRunner {
    private static final Random random = new Random();

    public static void pay(int rounds) {
        for (int i = 0; i < rounds; i++) {
            RoShaBoRunner.vs(randomOne(),randomOne());
        }
    }

    private static void vs(RoShaBo it1, RoShaBo it2) {
        System.out.println(String.format("%s VS %s: %s", it1.name(), it2.name(), it1.compet(it2).name()));
    }

    private static RoShaBo randomOne() {
        int nextInt = random.nextInt(3);
        switch(nextInt) {
            case 0:
                return RoShaBo.PAPER;
            case 1:
                return RoShaBo.SCISSORS;
            case 2:
                return RoShaBo.ROCK;
            default:
                return null;
        }
    }

    public static void main(String[] args) {
        pay(60);
    }
}

// 输出结果
ROCK VS ROCK: DRAW
ROCK VS PAPER: LOSE
PAPER VS PAPER: DRAW
PAPER VS ROCK: WIN
SCISSORS VS SCISSORS: DRAW
ROCK VS SCISSORS: WIN
SCISSORS VS ROCK: LOSE
SCISSORS VS PAPER: WIN
PAPER VS PAPER: DRAW
...

原文创作:沐风之境

原文链接:https://www.cnblogs.com/mufeng3421/p/12050002.html

更多推荐

更多
  • Pharo敏捷人工智能-第一部分:神经网络
    Apache CN

  • Pharo敏捷人工智能-第二部分:遗传算法
    Apache CN

  • Pharo敏捷人工智能-# 第三部分:神经进化 第三部分:神经进化
    Apache CN

  • Java编程思想-9.2 异常的捕获 9.2.1 try块,9.2.2 异常控制器,9.2.3 异常规范,9.2.4 捕获所有异常,9.2.5 重新“抛”出异常, 若某个方法产生一个异常,必须保证该异常能被捕获,并获得正确对待。对于Java的异常控制机制,它的一个好处
  • Java编程思想-9.3 标准Java异常 9.3.1 RuntimeException的特殊情况,Java包含了一个名为`Throwable`的类,它对可以作为异常“抛”出的所有东西进行了描述。`Throwable`对象有两种常规类型(亦即“从`Throwable`继
  • Java编程思想-第8章 对象的容纳 “如果一个程序只含有数量固定的对象,而且已知它们的存在时间,那么这个程序可以说是相当简单的。”通常,我们的程序需要根据程序运行时才知道的一些标准创建新对象。若非程序正式运行,否则我们根本不知道自己到底需要多少数量的对象,甚
  • Java编程思想-9.1 基本异常 9.1.1 异常参数, “异常条件”表示在出现什么问题的时候应中止方法或作用域的继续。为了将异常条件与普通问题区分开,异常条件是非常重要的一个因素。在普通问题的情况下,我们在当地已拥有足够的信息,可在某种程度上解决碰到的问题。而在
  • Java编程思想-9.5 异常的限制 覆盖一个方法时,只能产生已在方法的基类版本中定义的异常。这是一个重要的限制,因为它意味着与基类协同工作的代码也会自动应用于从基类派生的任何对象(当然,这属于基本的OOP概念),其中包括异常。下面这个例子演示了强加在异常身上
  • Java编程思想-9.4 创建自己的异常 并不一定非要使用Java异常。这一点必须掌握,因为经常都需要创建自己的异常,以便指出自己的库可能生成的一个特殊错误——但创建Java分级结构的时候,这个错误是无法预知的。为创建自己的异常类,必须从一个现有的异常类型继承——最
  • Java编程思想-8.8 总结 下面复习一下由标准Java(1.0和1.1)库提供的集合(`BitSet`未包括在这里,因为它更象一种负有特殊使命的类):(1) 数组包含了对象的数字化索引。它容纳的是一种已知类型的对象,所以在查找一个对象时,不必对结果进行
  • 近期文章

    更多
    文章目录

      推荐作者

      更多