CCF CSP 炉石传说 JAVA 201609-3 100分
这个题麻烦在角色的信息不好处理
想想其实也好处理,只需要封装一个角色类,将生命值和攻击力封装起来就好了
还有一点是随从进场位置,如果出现在左边要使右面所有随从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分相关推荐
- CCF 201612-3 炉石传说 JAVA实现
炉石传说 问题描述 <炉石传说:魔兽英雄传>(Hearthstone: Heroes of Warcraft,简称炉石传说)是暴雪娱乐开发的一款集换式卡牌游戏(如下图所示).游戏在一个战斗 ...
- CCF CSP 201609-2 火车购票(C++语言100分)[简单模拟题]
1. 问题链接:CCF 201609-2 火车购票 试题编号: 201609-2 试题名称: 火车购票 时间限制: 1.0s 内存限制: 256.0MB 问题描述: 问题描述 请实现一个铁路购票系统的 ...
- CCF CSP 201609-2 火车购票 C++实现 100分
问题描述 请实现一个铁路购票系统的简单座位分配算法,来处理一节车厢的座位分配. 假设一节车厢有20排.每一排5个座位.为方便起见,我们用1到100来给所有的座位编号,第一排是1到5号,第二排是6到10 ...
- CCF CSP 20190901 小明种苹果 100分 解法/思想
近几天正在疯狂的刷CCF题,写博客主要是做一下笔记以及记录一下自己的心得,如果能够帮到大家那就再好不过了,废话不多说,咱们放题: [题目概述] 小明(小明事情真多)要种苹果,需要疏果把不好的苹果去掉, ...
- CCF CSP 行车路线 java 201712_4
CCF CSP 行车路线 java 201712_4 问题描述 小明和小芳出去乡村玩,小明负责开车,小芳来导航. 小芳将可能的道路分为大道和小道.大道比较好走,每走1公里小明会增加1的疲劳度.小道不好 ...
- CSP201609-3(炉石传说)(Java 100分)(只有78行代码)
问题描述 <炉石传说:魔兽英雄传>(Hearthstone: Heroes of Warcraft,简称炉石传说)是暴雪娱乐开发的一款集换式卡牌游戏(如下图所示).游戏在一个战斗棋盘上进行 ...
- 炉石传说 java实现
试题编号: 201609-3 试题名称: 炉石传说 时间限制: 1.0s 内存限制: 256.0MB 问题描述: 问题描述 <炉石传说:魔兽英雄传>(Hearthstone: Heroes ...
- 程序设计思维与实践 csp路径解析、csp炉石传说
目录 路径解析 输入格式 输出格式 样例 想法: 代码: 炉石传说 描述: 输入格式: 输出格式: 样例: 评测用例规模与约定: 想法: 代码: 路径解析 描述: 在操作系统中,数据通常以文件的形式存 ...
- 炉石传说 java_炉石传说 java实现
试题编号: 201609-3 试题名称:炉石传说 时间限制:1.0s 内存限制:256.0MB 问题描述: 问题描述 <炉石传说:魔兽英雄传>(Hearthstone: Heroes of ...
最新文章
- 2021年大数据Hadoop(二十九):​​​​​​​关于YARN常用参数设置
- 2020 年,AI 芯片内存哪家强?
- C语言--对数组地址的解析
- linux -- ./configure --prefix 命令
- 【推荐】查找一代用户出口Userexit
- [云炬创业基础笔记]第十一章创业计划书测试11
- SQL注入之堆叠注入(sql-lab第38关)
- .NET Core 3 Preview 2发布,C#8更强大的模式匹配
- 电子游戏理论基础初探
- listary——一个强大的windows高效工具
- 易语言获取硬盘特征字序列号加密特征字
- series 锐捷rgrsr20_锐捷RG-RSR20-04E路由器
- C++ isalpha、isalnum、islower、isupper、tolower、toupper用法
- html 加爱心符号,心形符号大全
- 计算机实习生听课记录,实习生听课记录
- LIS3DH 三轴加速度传感器使用流程及示例
- macOS High Sierra 10.13.6 英伟达显卡Nvidia显卡 失效处理方案
- Zabbix5.0监控CenterOS(RPM版)
- D语言游戏编程(1):工作环境
- 使用Latex进行中文排版
热门文章
- 无线路由ntp服务器,CISCO路由器上配置NTP服务器
- 【翻译】对计算机未来的10个预测或;我们的首席科学家的无稽之谈
- 外星人Alienware x17 R2 评测
- 绝地求生12月18日服务器信息,绝地求生12月18日维护时间详情 12.18吃鸡更新维护公告...
- 查看某个IP端口是否开放
- 第一行输出一个1,第二行输出2个2······第N行输出N个N
- easyExcel动态复杂表头导出
- gis插入的文本怎么搞成两行_没有电脑怎么做PPT?用手机这样做!比电脑做出来的还要精美...
- 淘宝根据商品ID免费获取详细信息(实时价格、尺码、库存等) 超详细
- 每晚11点后电脑自动休眠的简单Java程序