关注
import java.util.Scanner;
public class AmberChallenge {
static final int MAX_WIND_FIELDS = 5;
static int[] windFields = new int[MAX_WIND_FIELDS];
static int windFieldCount = 0;
static int[] windRings = new int[MAX_WIND_FIELDS];
static int windRingCount = 0;
static boolean canReachDestination(int d, int h, int x, int y, int t,
int currentDistance, int currentHeight, int speedMultiplier,
int windRingRemainingTime) {
// 如果安柏落水或者飞过了目的地,返回false
if (currentHeight <= 0 || currentDistance > d) {
return false;
}
// 如果安柏到达了目的地,返回true
if (currentDistance == d && currentHeight == 0) {
return true;
}
// 如果安柏在风环效果中
if (windRingRemainingTime > 0) {
// 继续前进,保持当前的速度倍率
if (canReachDestination(d, h, x, y, t,
currentDistance + x * speedMultiplier,
currentHeight - y,
speedMultiplier,
windRingRemainingTime - 1)) {
return true;
}
} else {
// 如果不在风环效果里,检查是否可以进入一个风环
for (int i = 0; i < windRingCount; i++) {
if (currentDistance == windRings[i]) {
// 进入风环,速度倍率设置为2,重新设置风环效果时间
if (canReachDestination(d, h, x, y, t,
currentDistance,
currentHeight,
2,
t)) {
return true;
}
}
}
}
// 检查是否可以进入风场,如果可以,将高度设置为最大值
for (int i = 0; i < windFieldCount; i++) {
if (currentDistance == windFields[i]) {
if (canReachDestination(d, h, x, y, t,
currentDistance + x,
h,
speedMultiplier,
windRingRemainingTime)) {
return true;
}
}
}
// 没有进入风场也没有风环效果,正常飞行一次
return canReachDestination(d, h, x, y, t,
currentDistance + x,
currentHeight - y,
speedMultiplier,
windRingRemainingTime);
}
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
int testCases = scanner.nextInt();
while (testCases-- > 0) {
int d = scanner.nextInt(); // 目的地水平距离
int h = scanner.nextInt(); // 初始高度
int x = scanner.nextInt(); // 水平飞行速度
int y = scanner.nextInt(); // 垂直下降速度
int t = scanner.nextInt(); // 风环效果时间
windFieldCount = scanner.nextInt();
for (int i = 0; i < windFieldCount; i++) {
windFields[i] = scanner.nextInt();
}
windRingCount = scanner.nextInt();
for (int i = 0; i < windRingCount; i++) {
windRings[i] = scanner.nextInt();
}
boolean result = canReachDestination(d, h, x, y, t, 0, h, 1, 0);
System.out.println(result ? "YES" : "NO");
}
scanner.close();
}
}
查看原帖
点赞 1
相关推荐
07-22 11:53
门头沟学院 Java 点赞 评论 收藏
分享
牛客热帖
更多
正在热议
更多
# 哪些公司开提前批了? #
22483次浏览 240人参与
# 实习如何「偷」产出? #
46064次浏览 1182人参与
# 风评不好的公司,你会去吗? #
53914次浏览 388人参与
# 你今年的平均薪资是多少? #
133584次浏览 682人参与
# 除了主业以外,你还有哪些其他收入? #
10712次浏览 186人参与
# 互联网公司评价 #
400881次浏览 3836人参与
# 节后第一天上班,我的精神状态 #
13316次浏览 117人参与
# 不卡学历的大厂有哪些? #
25617次浏览 202人参与
# 校招阶段,学历VS技术哪个更重要? #
15933次浏览 176人参与
# 签约/解约注意事项 #
696615次浏览 4068人参与
# 职场新人体验 #
21880次浏览 207人参与
# 腾讯音乐求职进展汇总 #
97880次浏览 570人参与
# 正在实习的碎碎念 #
1453876次浏览 13469人参与
# 硬件人求职现状 #
434232次浏览 4539人参与
# 实习打杂,要跑路吗 #
17223次浏览 197人参与
# 宁德时代求职进展汇总 #
122601次浏览 650人参与
# Offer比较,你最看重什么? #
191319次浏览 1301人参与
# 校园里的破防时刻 #
9979次浏览 112人参与
# 社恐入职新公司如何融入团队 #
11677次浏览 63人参与
# 你投递的公司有几家约面了? #
108589次浏览 776人参与