java实现题目以及选项乱序的方法实例

前言

在现实生活中,考试是我们的必经之路,但是线上考试总有一部分人抄写答案,为了防止抄写,将题目和答案打乱,防止抄袭。本文实现通过map轮询时将选项乱序,最终答案也变化。

选择题类 ChoiceQuestion

import java.util.Map;

/**
 * 单选题
 */
public class ChoiceQuestion {

 private String name;     // 题目
 private Map<String, String> option; // 选项;A、B、C、D
 private String key;     // 答案;B

 public ChoiceQuestion() {
 }

 public ChoiceQuestion(String name, Map<String, String> option, String key) {
  this.name = name;
  this.option = option;
  this.key = key;
 }

 public String getName() {
  return name;
 }

 public void setName(String name) {
  this.name = name;
 }

 public Map<String, String> getOption() {
  return option;
 }

 public void setOption(Map<String, String> option) {
  this.option = option;
 }

 public String getKey() {
  return key;
 }

 public void setKey(String key) {
  this.key = key;
 }
}

处理后选项答案临时对象 Topic

public class Topic {

 private Map<String, String> option; // 选项;A、B、C、D
 private String key;   // 答案;B

 public Topic() {
 }

 public Topic(Map<String, String> option, String key) {
  this.option = option;
  this.key = key;
 }

 public Map<String, String> getOption() {
  return option;
 }

 public void setOption(Map<String, String> option) {
  this.option = option;
 }

 public String getKey() {
  return key;
 }

 public void setKey(String key) {
  this.key = key;
 }
}

测试类

/**
 * @date 2021/3/3 16:54
 * @version: 1.0
 */
public class QuestionTest {
 /**
  * 输出对于考生的题目
  * @param candidate
  * @param number
  */
 public static void output(String candidate, String number){
  Map<String, String> map01 = new HashMap<String, String>();
  map01.put("A", "JAVA2 EE");
  map01.put("B", "JAVA2 Card");
  map01.put("C", "JAVA2 ME");
  map01.put("D", "JAVA2 HE");
  map01.put("E", "JAVA2 SE");

  Map<String, String> map02 = new HashMap<String, String>();
  map02.put("A", "JAVA程序的main方法必须写在类里面");
  map02.put("B", "JAVA程序中可以有多个main方法");
  map02.put("C", "JAVA程序中类名必须与文件名一样");
  map02.put("D", "JAVA程序的main方法中如果只有一条语句,可以不用{}(大括号)括起来");

  Map<String, String> map03 = new HashMap<String, String>();
  map03.put("A", "变量由字母、下划线、数字、$符号随意组成;");
  map03.put("B", "变量不能以数字作为开头;");
  map03.put("C", "A和a在java中是同一个变量;");
  map03.put("D", "不同类型的变量,可以起相同的名字;");

  Map<String, String> map04 = new HashMap<String, String>();
  map04.put("A", "STRING");
  map04.put("B", "x3x;");
  map04.put("C", "void");
  map04.put("D", "de$f");

  Map<String, String> map05 = new HashMap<String, String>();
  map05.put("A", "31");
  map05.put("B", "0");
  map05.put("C", "1");
  map05.put("D", "2");
  ArrayList<ChoiceQuestion> choiceQuestionList = new ArrayList<ChoiceQuestion>();
  choiceQuestionList.add(new ChoiceQuestion("JAVA所定义的版本中不包括", map01, "D"));
  choiceQuestionList.add(new ChoiceQuestion("下列说法正确的是", map02, "A"));
  choiceQuestionList.add(new ChoiceQuestion("以下()不是合法的标识符",map04, "C"));
  choiceQuestionList.add(new ChoiceQuestion("表达式(11+3*8)/4%3的值是", map05, "D"));
  choiceQuestionList.add(new ChoiceQuestion("变量命名规范说法正确的是", map03, "B"));
  //题目顺序打乱
  Collections.shuffle(choiceQuestionList);
  // 选项-答案乱序
  for (ChoiceQuestion question : choiceQuestionList) {
   Topic random = random(question.getOption(), question.getKey());
   question.setOption(random.getOption());
   question.setKey(random.getKey());
  }
  //输出打印
  System.out.println(toString(choiceQuestionList, candidate, number));
 }

 /**
  * 打乱选项和答案
  * @param option
  * @param key
  * @return
  */
 public static Topic random(Map<String, String> option, String key) {
  Set<String> keySet = option.keySet();
  ArrayList<String> keyList = new ArrayList<String>(keySet);
  Collections.shuffle(keyList);
  HashMap<String, String> optionNew = new HashMap<String, String>();
  int idx = 0;
  String keyNew = "";
  for (String next : keySet) {
   String randomKey = keyList.get(idx++);
   if (key.equals(next)) {
    keyNew = randomKey;
   }
   optionNew.put(randomKey, option.get(next));
  }
  return new Topic(optionNew, keyNew);
 }

 public static String toString(ArrayList<ChoiceQuestion> choiceQuestionList,String candidate, String number) {

  StringBuilder detail = new StringBuilder("考生:" + candidate + "\r\n" +
    "考号:" + number + "\r\n" +
    "--------------------------------------------\r\n" +
    "一、选择题" + "\r\n\n");

  for (int idx = 0; idx < choiceQuestionList.size(); idx++) {
   detail.append("第").append(idx + 1).append("题:").append(choiceQuestionList.get(idx).getName()).append("\r\n");
   Map<String, String> option = choiceQuestionList.get(idx).getOption();
   for (String key : option.keySet()) {
    detail.append(key).append(":").append(option.get(key)).append("\r\n");;
   }
   detail.append("答案:").append(choiceQuestionList.get(idx).getKey()).append("\r\n\n");
  }

  return detail.toString();
 }

 public static void main(String[] args) {
  output("花花", "1000001921032");
  output("豆豆", "1000001921051");
  output("大宝", "1000001921987");
 }
}

输出结果

考生:花花
考号:1000001921032
--------------------------------------------
一、选择题

第1题:JAVA所定义的版本中不包括
A:JAVA2 HE
B:JAVA2 ME
C:JAVA2 SE
D:JAVA2 Card
E:JAVA2 EE
答案:A

第2题:下列说法正确的是
A:JAVA程序中可以有多个main方法
B:JAVA程序中类名必须与文件名一样
C:JAVA程序的main方法必须写在类里面
D:JAVA程序的main方法中如果只有一条语句,可以不用{}(大括号)括起来
答案:C

第3题:以下()不是合法的标识符
A:x3x;
B:void
C:de$f
D:STRING
答案:B

第4题:表达式(11+3*8)/4%3的值是
A:0
B:31
C:1
D:2
答案:D

第5题:变量命名规范说法正确的是
A:变量不能以数字作为开头;
B:A和a在java中是同一个变量;
C:变量由字母、下划线、数字、$符号随意组成;
D:不同类型的变量,可以起相同的名字;
答案:A

考生:豆豆
考号:1000001921051
--------------------------------------------
一、选择题

第1题:JAVA所定义的版本中不包括
A:JAVA2 Card
B:JAVA2 EE
C:JAVA2 SE
D:JAVA2 HE
E:JAVA2 ME
答案:D

第2题:下列说法正确的是
A:JAVA程序的main方法必须写在类里面
B:JAVA程序的main方法中如果只有一条语句,可以不用{}(大括号)括起来
C:JAVA程序中可以有多个main方法
D:JAVA程序中类名必须与文件名一样
答案:A

第3题:以下()不是合法的标识符
A:void
B:x3x;
C:de$f
D:STRING
答案:A

第4题:表达式(11+3*8)/4%3的值是
A:31
B:2
C:0
D:1
答案:B

第5题:变量命名规范说法正确的是
A:A和a在java中是同一个变量;
B:变量由字母、下划线、数字、$符号随意组成;
C:变量不能以数字作为开头;
D:不同类型的变量,可以起相同的名字;
答案:C

考生:大宝
考号:1000001921987
--------------------------------------------
一、选择题

第1题:JAVA所定义的版本中不包括
A:JAVA2 ME
B:JAVA2 Card
C:JAVA2 SE
D:JAVA2 HE
E:JAVA2 EE
答案:D

第2题:下列说法正确的是
A:JAVA程序中类名必须与文件名一样
B:JAVA程序的main方法必须写在类里面
C:JAVA程序中可以有多个main方法
D:JAVA程序的main方法中如果只有一条语句,可以不用{}(大括号)括起来
答案:B

第3题:以下()不是合法的标识符
A:STRING
B:de$f
C:void
D:x3x;
答案:C

第4题:表达式(11+3*8)/4%3的值是
A:2
B:0
C:1
D:31
答案:A

第5题:变量命名规范说法正确的是
A:不同类型的变量,可以起相同的名字;
B:变量不能以数字作为开头;
C:变量由字母、下划线、数字、$符号随意组成;
D:A和a在java中是同一个变量;
答案:B

本文参考 bugstack⾍洞栈 作者设计模式一书原型模式 提取选项答案乱序逻辑修改

总结

到此这篇关于java实现题目以及选项乱序的文章就介绍到这了,更多相关java题目选项乱序内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • java实现题目以及选项乱序的方法实例

    前言 在现实生活中,考试是我们的必经之路,但是线上考试总有一部分人抄写答案,为了防止抄写,将题目和答案打乱,防止抄袭.本文实现通过map轮询时将选项乱序,最终答案也变化. 选择题类 ChoiceQuestion import java.util.Map; /** * 单选题 */ public class ChoiceQuestion { private String name; // 题目 private Map<String, String> option; // 选项:A.B.C.D p

  • Java中List排序的三种实现方法实例

    目录 前言 1.使用 Comparable 排序 2.使用 Comparator 排序 2.1 新建 Comparator 比较器 2.2 匿名类比较器 3.使用 Stream 流排序 总结 前言 在某些特殊的场景下,我们需要在 Java 程序中对 List 集合进行排序操作.比如从第三方接口中获取所有用户的列表,但列表默认是以用户编号从小到大进行排序的,而我们的系统需要按照用户的年龄从大到小进行排序,这个时候,我们就需要对 List 集合进行自定义排序操作了. ​List 排序的常见方法有以下

  • Java使用阻塞队列控制线程通信的方法实例详解

    本文实例讲述了Java使用阻塞队列控制线程通信的方法.分享给大家供大家参考,具体如下: 一 点睛 阻塞队列主要用在生产者/消费者的场景,下面这幅图展示了一个线程生产.一个线程消费的场景: 负责生产的线程不断的制造新对象并插入到阻塞队列中,直到达到这个队列的上限值.队列达到上限值之后生产线程将会被阻塞,直到消费的线程对这个队列进行消费.同理,负责消费的线程不断的从队列中消费对象,直到这个队列为空,当队列为空时,消费线程将会被阻塞,除非队列中有新的对象被插入. BlockingQueue的核心方法:

  • JAVA读取文件夹大小的几种方法实例

    (一)单线程递归方式 复制代码 代码如下: package com.taobao.test; import java.io.File; public class TotalFileSizeSequential { public static String fileName = "C:\\Documents and Settings\\Administrator\\桌面\\monkeytalk"; // 递归方式 计算文件的大小    private long getTotalSizeO

  • Java多线程实现简易微信发红包的方法实例

    一. 首先我们先大致了解一下什么是多线程.(书上的解释) 程序是一段静态的代码,它是应用软件的蓝本.进程是程序的一次动态执行过程,对应了从代码加载执行,执行到执行完毕的一个完整的过程. 线程不是进程,线程是比进程更小的执行单位,一个进程在其执行过程中,可以产生多个线程形成多条执行线索,每条线索即每个线程也有它自身的产生,存在,消亡的过程,和进程共享操作系统的资源类似,线程间也可以共享进程中的某些内存单元,并利用这些共享单元来实现数据交换,实时通信与必要的同步操作,但与进程不同的是线程的中断和恢复

  • java递归法求字符串逆序

    本文实例讲述了java递归法求字符串逆序的方法.分享给大家供大家参考.具体实现方法如下: public static String reverseString(String x) { if(x==null || x.length()<2) return x; return reverseString(x.substring(1,x.length()))+ x.charAt(0); } 希望本文所述对大家的java程序设计有所帮助.

  • python生成不重复随机数和对list乱序的解决方法

    andom.sample(list, n)即是从list中随机选取n个不同的元素 # -*- coding: utf-8 -*- import random # 从一个list中随机挑选5个 list = [12, 23, 13, 14, 78, 234, 123, 12345] randomlist = random.sample(list, 5) print randomlist # 在range(10)中随机生成5个不重复的数,可以作为随机下标集合,然后到list中取数 len = lis

  • OpenCV实现乱序碎片复原

    目录 题目 算法思路 源码展示 结果演示 题目 将4张打乱顺序的碎片拼接复原并展示原图 算法思路 将x张碎片的左右边缘提取保存 左右边缘两两对比,将相似度超过预设阈值的碎片执行拼接操作,得到左右拼接好的碎片 提取左右拼接好的碎片的上下边缘 上下边缘两两对比,将相似度超过预设阈值的碎片执行拼接操作,得到原图 源码展示 #include <opencv2/opencv.hpp> #include "opencv2/core/core.hpp" #include "op

  • JavaScript中实现最高效的数组乱序方法

    数组乱序的意思是,把数组内的所有元素排列顺序打乱. 常用的办法是给数组原生的sort方法传入一个函数,此函数随机返回1或-1,达到随机排列数组元素的目的. 复制代码 代码如下: arr.sort(function(a,b){ return Math.random()>.5 ? -1 : 1;}); 这种方法虽直观,但效率并不高,经我测试,打乱10000个元素的数组,所用时间大概在35ms上下(firefox) 本人一直具有打破沙锅问到底的优良品质,于是搜索到了一个高效的方法.原文见此 复制代码

  • java实现单链表之逆序

    下面一段代码准确的介绍了java实现单链表逆序,具体内容就不做详解了,有需要的朋友可以直接拷贝了 package com.ckw.mianshi; /** * java 实现单链表的逆序 * @author Administrator * */ public class SingleLinkedReverse { class Node{ int data; Node next; public Node(int data){ this.data = data; } } public static

随机推荐