这个题麻烦在角色的信息不好处理

想想其实也好处理,只需要封装一个角色类,将生命值和攻击力封装起来就好了

还有一点是随从进场位置,如果出现在左边要使右面所有随从position+1

其实也好处理,正好!用Link接口实现的有add(index,element)方法,数据在列表中的位置可以完美的表示不同随从的position

更完美的是:“任意时刻,战场上的随从总是从1开始连续编号。”

简直是提醒你用这个方法。

最后注意输出顺序和间隔就好。

package csp2016_09_3;import java.util.ArrayList;
import java.util.List;
import java.util.Scanner;class Role{int life,power;Role(int life,int power){this.life = life;this.power=power;}Role(int life){this.life=life;}
}public class Main{static List<Role> p[] = new ArrayList[2];public static void main(String[] args){Scanner sc = new Scanner(System.in);int n = sc.nextInt();sc.nextLine();for (int i = 0; i < p.length; i++) {p[i] = new ArrayList<Role>();p[i].add(new Role(30,0));}int player = 0;int pos=0,attack=0,health=0;int attacker=0,defender=0;while((n--)!=0){String action = sc.next();if(action.equals("summon")){pos = sc.nextInt();attack = sc.nextInt();health = sc.nextInt();
//              System.out.println(pos+" "+attack+" "+health);p[player].add(pos, new Role(health,attack));}else if(action.equals("attack")){attacker = sc.nextInt();defender = sc.nextInt();//              System.out.println(player+" "+attacker+" "+defender);
//
//              for (int i = 0; i < p.length; i++) {
//                  for (int j = 0; j < p[i].size(); j++) {
//                      int pp = p[i].get(j).power;
//                      int hh = p[i].get(j).life;
//                      System.out.print(pp+" "+hh+"||");
//                  }
//                  System.out.println("||");
//              }
//              System.out.println(p[player].get(attacker).life+" "+p[player].get(attacker).power);
//              System.out.println(p[1-player].get(defender).life+" "+p[1-player].get(defender).power);p[player].get(attacker).life -= p[1-player].get(defender).power; p[1-player].get(defender).life -= p[player].get(attacker).power;if(p[player].get(attacker).life <= 0){p[player].remove(attacker);}if(defender!=0 && p[1-player].get(defender).life <= 0){p[1-player].remove(defender);}}else if(action.equals("end")){player = 1-player;}else{System.out.println("error");}}//1if(p[0].get(0).life <=0 ) System.out.println(-1);else if(p[1].get(0).life <=0) System.out.println(1);else System.out.println(0);//2System.out.println(p[0].get(0).life);//3System.out.print(p[0].size()-1+" ");for (int i = 1; i < p[0].size(); i++) {System.out.print(p[0].get(i).life+" ");}System.out.println();//4System.out.println(p[1].get(0).life);//5System.out.print(p[1].size()-1+" ");for (int i = 1; i < p[1].size(); i++) {System.out.print(p[1].get(i).life+" ");}}
}

CCF CSP 炉石传说 JAVA 201609-3 100分相关推荐

  1. CCF 201612-3 炉石传说 JAVA实现

    炉石传说 问题描述 <炉石传说:魔兽英雄传>(Hearthstone: Heroes of Warcraft,简称炉石传说)是暴雪娱乐开发的一款集换式卡牌游戏(如下图所示).游戏在一个战斗 ...

  2. CCF CSP 201609-2 火车购票(C++语言100分)[简单模拟题]

    1. 问题链接:CCF 201609-2 火车购票 试题编号: 201609-2 试题名称: 火车购票 时间限制: 1.0s 内存限制: 256.0MB 问题描述: 问题描述 请实现一个铁路购票系统的 ...

  3. CCF CSP 201609-2 火车购票 C++实现 100分

    问题描述 请实现一个铁路购票系统的简单座位分配算法,来处理一节车厢的座位分配. 假设一节车厢有20排.每一排5个座位.为方便起见,我们用1到100来给所有的座位编号,第一排是1到5号,第二排是6到10 ...

  4. CCF CSP 20190901 小明种苹果 100分 解法/思想

    近几天正在疯狂的刷CCF题,写博客主要是做一下笔记以及记录一下自己的心得,如果能够帮到大家那就再好不过了,废话不多说,咱们放题: [题目概述] 小明(小明事情真多)要种苹果,需要疏果把不好的苹果去掉, ...

  5. CCF CSP 行车路线 java 201712_4

    CCF CSP 行车路线 java 201712_4 问题描述 小明和小芳出去乡村玩,小明负责开车,小芳来导航. 小芳将可能的道路分为大道和小道.大道比较好走,每走1公里小明会增加1的疲劳度.小道不好 ...

  6. CSP201609-3(炉石传说)(Java 100分)(只有78行代码)

    问题描述 <炉石传说:魔兽英雄传>(Hearthstone: Heroes of Warcraft,简称炉石传说)是暴雪娱乐开发的一款集换式卡牌游戏(如下图所示).游戏在一个战斗棋盘上进行 ...

  7. 炉石传说 java实现

    试题编号: 201609-3 试题名称: 炉石传说 时间限制: 1.0s 内存限制: 256.0MB 问题描述: 问题描述 <炉石传说:魔兽英雄传>(Hearthstone: Heroes ...

  8. 程序设计思维与实践 csp路径解析、csp炉石传说

    目录 路径解析 输入格式 输出格式 样例 想法: 代码: 炉石传说 描述: 输入格式: 输出格式: 样例: 评测用例规模与约定: 想法: 代码: 路径解析 描述: 在操作系统中,数据通常以文件的形式存 ...

  9. 炉石传说 java_炉石传说 java实现

    试题编号: 201609-3 试题名称:炉石传说 时间限制:1.0s 内存限制:256.0MB 问题描述: 问题描述 <炉石传说:魔兽英雄传>(Hearthstone: Heroes of ...

最新文章

  1. 2021年大数据Hadoop(二十九):​​​​​​​关于YARN常用参数设置
  2. 2020 年,AI 芯片内存哪家强?
  3. C语言--对数组地址的解析
  4. linux -- ./configure --prefix 命令
  5. 【推荐】查找一代用户出口Userexit
  6. [云炬创业基础笔记]第十一章创业计划书测试11
  7. SQL注入之堆叠注入(sql-lab第38关)
  8. .NET Core 3 Preview 2发布,C#8更强大的模式匹配
  9. 电子游戏理论基础初探
  10. listary——一个强大的windows高效工具
  11. 易语言获取硬盘特征字序列号加密特征字
  12. series 锐捷rgrsr20_锐捷RG-RSR20-04E路由器
  13. C++ isalpha、isalnum、islower、isupper、tolower、toupper用法
  14. html 加爱心符号,心形符号大全
  15. 计算机实习生听课记录,实习生听课记录
  16. LIS3DH 三轴加速度传感器使用流程及示例
  17. macOS High Sierra 10.13.6 英伟达显卡Nvidia显卡 失效处理方案
  18. Zabbix5.0监控CenterOS(RPM版)
  19. D语言游戏编程(1):工作环境
  20. 使用Latex进行中文排版

热门文章

  1. 无线路由ntp服务器,CISCO路由器上配置NTP服务器
  2. 【翻译】对计算机未来的10个预测或;我们的首席科学家的无稽之谈
  3. 外星人Alienware x17 R2 评测
  4. 绝地求生12月18日服务器信息,绝地求生12月18日维护时间详情 12.18吃鸡更新维护公告...
  5. 查看某个IP端口是否开放
  6. 第一行输出一个1,第二行输出2个2······第N行输出N个N
  7. easyExcel动态复杂表头导出
  8. gis插入的文本怎么搞成两行_没有电脑怎么做PPT?用手机这样做!比电脑做出来的还要精美...
  9. 淘宝根据商品ID免费获取详细信息(实时价格、尺码、库存等) 超详细
  10. 每晚11点后电脑自动休眠的简单Java程序