机_气_人
2017-05-14 16:45
采纳率: 100%
浏览 1.9k
已采纳

Java编程,类似与游戏匹配

求帮忙编一段小程序,大体要求如下:
改程序模拟游戏组队情况,最多为4个人一组。
可以依次随机录入一名玩家,两名玩家,三名玩家,四名玩家。
每次录入为一组成员,成员不可以从组内剥离,组内顺序无所谓。
比如:
在等待队列里,依次(按照进入队列的先后顺序)为
【AA,AAA】,【BBB】,【APPLE,SUN,SONG,GIRL】,【CCC】,【GGE,LLL,KKK,EFE】,【III,ERE,OUO】
现在可以选择1,2,3,4 名玩家出列,选出后从等待队列删除
例如:依次选出2名玩家,两名玩家,三名玩家
结果依次为:【AA,AAA】被选出,【BBB】和【CCC】被选出,【III,ERE,OUO】被选出
在例如:依次选出4名玩家,4名玩家,4名玩家
结果是:【AA,AAA】和【BBB】和【CCC】
【APPLE,SUN,SONG,GIRL】
【GGE,LLL,KKK,EFE】
此时等待队列里还有一组【III,ERE,OUO】

总结来说就是根据手动录入的先后顺序和小组的大小,进行组合
  • 写回答
  • 好问题 提建议
  • 关注问题
  • 收藏
  • 邀请回答

2条回答 默认 最新

  • 机_气_人 2017-05-16 00:27
    已采纳

    已经搞定了,一下是主要的代码

    private List remove(List list, int n){
    E[] es = list.get(0);
    List result = new LinkedList();
    if(es.length==n)
    Collections.addAll(result, list.remove(0));
    if(es.length n = n- es.length;
    result.addAll(remove(list.subList(1, list.size()), n));
    if(result.size()!=0)
    Collections.addAll(result, list.remove(0));
    }
    if(es.length>n&&list.size()>1)
    return remove(list.subList(1, list.size()), n);
    return result;
    }

    
    
    已采纳该答案
    评论
    解决 无用
    打赏 举报
  • 查看更多回答(1条)

相关推荐 更多相似问题