华硕编程竞赛11月JAVA专场 E题太空漫步 题解

简介: 华硕编程竞赛11月JAVA专场 E题太空漫步 题解

题目链接:题目链接

题面:

小王在体验 “飞机大战” 后,将自己送到了太空。突然,小王失去了重力,在空中停了下来!

没等小王反应过来,一座闪闪发光的天桥映入小王的眼帘,这是一座长度为 N(0 <= N <= 200000) 的天桥,即小王当前位置和终点之间有 N 个踏板。

每个踏板上由三个子踏板,分别为 J 、Q 、K,腿短的小王无法跨越多个踏板,即每个踏板必须踏一次,每次必须选择踏板中的某个子踏板(J、Q、K之一),如下图所示。

这个天桥踏板还有一个特殊机制,如果小王连续脚踏三段不一致的子踏板,小王就会坠落,掉入无限深渊!

比如经过长度为 3 的天桥,小王可以选择依次踏 JJJJQJ,然后安全到达终点。

如果小王依次踏 JQKKQJ,就会坠落。

小王想知道,自己安全到达天桥终点的踏法有几种?

本题需要你至少了解一些 Java 中数组的使用,了解递推的演算方式,为了降低时间复杂度,建议您采用打表的求解方式。

引用说明:上面的图片来源于蓝桥云课。

知识点

  • Java 数组基本语法
  • 递推运算
  • 打表

初始代码

public class DMain {
    public static int doWork(int n) {
        int ans = 1;
        //代码编辑区 开始
        //代码编辑区 结束
        return ans;
    }
    public static void main(String[] args) {
        //测试用例
        System.out.printf((Objects.equals(2048L,doWork(2)) ? "【√正确】" : "【X错误】") + "天桥长度 %d,通过方法为%d种\n",2,doWork(2));
    }
}

样例说明

输入天桥长度 N,输出安全到达天桥终点的踏法有几种。

如天桥长度 N = 2,则输出 9。

如天桥长度 N = 3,则输出 21。

题解

递推题,递推公式Fn(i) = 2 * Fn(i - 1) + Fn(i - 2),需要注意必须打表,否则会超时。

参考代码如下。

参考代码如下:

import java.util.ArrayList;
import java.util.List;
import java.util.Objects;
public class DAns {
    public static boolean INIT_FLAG = false;
    public static List<Integer> ANS_LIST;
    public static int doWork(int n) {
        int ans = 1;
        //代码编辑区 开始
        if(!INIT_FLAG) {
            init();
        }
        ans = ANS_LIST.get(n);
        //代码编辑区 结束
        return ans;
    }
    private static void init() {
        ANS_LIST = new ArrayList<>();
        ANS_LIST.add(0);
        ANS_LIST.add(3);
        ANS_LIST.add(9);
        for(int i = 3; i <= 100000; i ++) {
            ANS_LIST.add(2 * ANS_LIST.get(i - 1) + ANS_LIST.get(i - 2));
        }
        INIT_FLAG = true;
    }
    public static void main(String[] args) {
        //测试用例
        System.out.printf((Objects.equals(9,doWork(2)) ? "【√正确】" : "【X错误】") + "天桥长度 %d,通过方法为%d种\n",2,doWork(2));
        System.out.printf((Objects.equals(21,doWork(3)) ? "【√正确】" : "【X错误】") + "天桥长度 %d,通过方法为%d种\n",3,doWork(3));
    }
    private static int run(int n) {
        if(Objects.equals(1,n)) {
            return 3;
        } else if(Objects.equals(2,n)) {
            return 9;
        } else {
            return 2 * run(n - 1) + run(n - 2);
        }
    }
}

总结

要 AC 本题,必须学会递推的算法,找到递推数组的关系公式,并需要预先打表降低时间复杂度,最终通过本题。


相关文章
|
17天前
|
Java 程序员
Java编程中的异常处理:从基础到高级
在Java的世界中,异常处理是代码健壮性的守护神。本文将带你从异常的基本概念出发,逐步深入到高级用法,探索如何优雅地处理程序中的错误和异常情况。通过实际案例,我们将一起学习如何编写更可靠、更易于维护的Java代码。准备好了吗?让我们一起踏上这段旅程,解锁Java异常处理的秘密!
|
1天前
|
算法 Java 调度
java并发编程中Monitor里的waitSet和EntryList都是做什么的
在Java并发编程中,Monitor内部包含两个重要队列:等待集(Wait Set)和入口列表(Entry List)。Wait Set用于线程的条件等待和协作,线程调用`wait()`后进入此集合,通过`notify()`或`notifyAll()`唤醒。Entry List则管理锁的竞争,未能获取锁的线程在此排队,等待锁释放后重新竞争。理解两者区别有助于设计高效的多线程程序。 - **Wait Set**:线程调用`wait()`后进入,等待条件满足被唤醒,需重新竞争锁。 - **Entry List**:多个线程竞争锁时,未获锁的线程在此排队,等待锁释放后获取锁继续执行。
24 12
|
21天前
|
缓存 Java 开发者
Java多线程编程的陷阱与最佳实践####
本文深入探讨了Java多线程编程中常见的陷阱,如竞态条件、死锁和内存一致性错误,并提供了实用的避免策略。通过分析典型错误案例,本文旨在帮助开发者更好地理解和掌握多线程环境下的编程技巧,从而提升并发程序的稳定性和性能。 ####
|
14天前
|
安全 算法 Java
Java多线程编程中的陷阱与最佳实践####
本文探讨了Java多线程编程中常见的陷阱,并介绍了如何通过最佳实践来避免这些问题。我们将从基础概念入手,逐步深入到具体的代码示例,帮助开发者更好地理解和应用多线程技术。无论是初学者还是有经验的开发者,都能从中获得有价值的见解和建议。 ####
|
14天前
|
Java 调度
Java中的多线程编程与并发控制
本文深入探讨了Java编程语言中多线程编程的基础知识和并发控制机制。文章首先介绍了多线程的基本概念,包括线程的定义、生命周期以及在Java中创建和管理线程的方法。接着,详细讲解了Java提供的同步机制,如synchronized关键字、wait()和notify()方法等,以及如何通过这些机制实现线程间的协调与通信。最后,本文还讨论了一些常见的并发问题,例如死锁、竞态条件等,并提供了相应的解决策略。
38 3
|
19天前
|
开发框架 安全 Java
Java 反射机制:动态编程的强大利器
Java反射机制允许程序在运行时检查类、接口、字段和方法的信息,并能操作对象。它提供了一种动态编程的方式,使得代码更加灵活,能够适应未知的或变化的需求,是开发框架和库的重要工具。
35 2
|
20天前
|
安全 Java 开发者
Java中的多线程编程:从基础到实践
本文深入探讨了Java多线程编程的核心概念和实践技巧,旨在帮助读者理解多线程的工作原理,掌握线程的创建、管理和同步机制。通过具体示例和最佳实践,本文展示了如何在Java应用中有效地利用多线程技术,提高程序性能和响应速度。
54 1
|
6天前
|
安全 Java API
java如何请求接口然后终止某个线程
通过本文的介绍,您应该能够理解如何在Java中请求接口并根据返回结果终止某个线程。合理使用标志位或 `interrupt`方法可以确保线程的安全终止,而处理好网络请求中的各种异常情况,可以提高程序的稳定性和可靠性。
36 6
|
21天前
|
设计模式 Java 开发者
Java多线程编程的陷阱与解决方案####
本文深入探讨了Java多线程编程中常见的问题及其解决策略。通过分析竞态条件、死锁、活锁等典型场景,并结合代码示例和实用技巧,帮助开发者有效避免这些陷阱,提升并发程序的稳定性和性能。 ####
|
19天前
|
存储 监控 小程序
Java中的线程池优化实践####
本文深入探讨了Java中线程池的工作原理,分析了常见的线程池类型及其适用场景,并通过实际案例展示了如何根据应用需求进行线程池的优化配置。文章首先介绍了线程池的基本概念和核心参数,随后详细阐述了几种常见的线程池实现(如FixedThreadPool、CachedThreadPool、ScheduledThreadPool等)的特点及使用场景。接着,通过一个电商系统订单处理的实际案例,分析了线程池参数设置不当导致的性能问题,并提出了相应的优化策略。最终,总结了线程池优化的最佳实践,旨在帮助开发者更好地利用Java线程池提升应用性能和稳定性。 ####
下一篇
DataWorks