华硕编程竞赛11月JAVA专场 A题自由弹簧 题解

简介: 华硕编程竞赛11月JAVA专场 A题自由弹簧 题解

题目链接:题目链接

题面:

小王一直都想在太空遨游,但是现在的他并没有这个超能力,所以他买了个 “自由弹簧” 打算过过瘾。

这个 ”自由弹簧“ 在初次使用时,会将小王弹射到 N( 2 <= N <= 200000) 米的高度,当弹簧落地时,会触发 ”自由弹簧“ 的超能力,会自动将小王弹射到 N * N 米的高度!

”自由弹簧“ 的生产者设置了一道保护机制,当弹射高度 N 超过 100000007 米时,会自动将高度降低 N % 100000007 米的位置,以此保证小王的安全。

但 ”自由弹簧“ 也有使用寿命,当落地 M ( 2 <= M <= 200000)次(不含初次使用时的落地情况)之后,将不会再进行弹射,最终会将小王安全送回地面,并且自动消失。

小王想知道,当 ”自由弹簧“ 最后一次弹射时,会弹射到多高的高度 X ?(米,如 X 超过100000007 ,则求自动降低后的高度)

本次挑战需要你至少了解一些 Java 中整数的基本运算和幂运算,了解快速幂的计算流程。

知识点

  • 整数的基本运算
  • 整数幂运算
  • 快速幂取模

初始代码

public class AMain {
    private static final long MOD = 100000007;
    // 请勿修改 doWork() 的方法名和参数类型
    public static long doWork(long n,long m) {
        long ans = 1;
        //代码编辑区 开始
        //代码编辑区 结束
        return ans;
    }
    public static void main(String[] args) {
        //测试用例
        System.out.printf((Objects.equals(2048L,doWork(2, 10)) ? "【√正确】" : "【X错误】") + "初始速度%d,寿命%d次,最后弹射高度%d\n",2,10,doWork(2, 10));
        System.out.printf((Objects.equals(729L,doWork(3, 5)) ? "【√正确】" : "【X错误】") + "初始速度%d,寿命%d次,最后弹射高度%d\n",3,5,doWork(3, 5));
        System.out.printf((Objects.equals(29516713L,doWork(9, 11)) ? "【√正确】" : "【X错误】") + "初始速度%d,寿命%d次,最后弹射高度%d\n",3,5,doWork(9, 11));
        System.out.printf((Objects.equals(99898098L,doWork(99999, 88888)) ? "【√正确】" : "【X错误】") + "初始速度%d,寿命%d次,最后弹射高度%d\n",99999,88888,doWork(99999, 88888));
    }
}

样例说明

输入首次弹射高度 N 和弹射次数 M,输出最后一次弹射的高度。

如首次弹射高度 N = 2,弹射次数为 10,最后一次弹射的高度为 2048 米,则输出 2048。

如首次弹射高度 N = 3,弹射次数为 5,最后一次弹射的高度为 729 米,则输出 729。

如首次弹射高度 N = 9,弹射次数为 11,最后一次弹射的高度为 29516713 米,则输出 29516713 。

题解

签到题,考察快速幂取模,对于初次使用高度 N 和使用寿命次数 M,最后一次弹射高度等于 N 的 (M + 1) 次幂对 100000007 取模

参考代码如下:

import java.util.Objects;
public class AAns {
    private static final long MOD = 100000007;
    public static long doWork(long n,long m) {
        long ans = 1;
        //代码编辑区 开始
        m ++;
        long number = n % MOD;
        while(m > 0) {
            if((m & 1) > 0) {
                ans = (ans * number) % MOD;
            }
            number = (number * number) % MOD;
            m /= 2;
        }
        //代码编辑区 结束
        return ans;
    }
    public static void main(String[] args) {
        //测试用例
        System.out.printf((Objects.equals(2048L,doWork(2, 10)) ? "【√正确】" : "【X错误】") + "初始速度%d,寿命%d次,最后弹射高度%d\n",2,10,doWork(2, 10));
        System.out.printf((Objects.equals(729L,doWork(3, 5)) ? "【√正确】" : "【X错误】") + "初始速度%d,寿命%d次,最后弹射高度%d\n",3,5,doWork(3, 5));
        System.out.printf((Objects.equals(29516713L,doWork(9, 11)) ? "【√正确】" : "【X错误】") + "初始速度%d,寿命%d次,最后弹射高度%d\n",3,5,doWork(9, 11));
        System.out.printf((Objects.equals(99898098L,doWork(99999, 88888)) ? "【√正确】" : "【X错误】") + "初始速度%d,寿命%d次,最后弹射高度%d\n",99999,88888,doWork(99999, 88888));
    }
}

总结

要 AC 本题,必须学会快速幂取模的算法。

使用快速幂取模可以将原有的 O(N)的时间复杂度降为 O(log (2,N)),从而通过本题。


相关文章
|
1月前
|
Java
如何在Java中进行多线程编程
Java多线程编程常用方式包括:继承Thread类、实现Runnable接口、Callable接口(可返回结果)及使用线程池。推荐线程池以提升性能,避免频繁创建线程。结合同步与通信机制,可有效管理并发任务。
140 6
|
1月前
|
IDE Java 编译器
java编程最基础学习
Java入门需掌握:环境搭建、基础语法、面向对象、数组集合与异常处理。通过实践编写简单程序,逐步深入学习,打牢编程基础。
176 0
|
2月前
|
SQL Java 数据库
2025 年 Java 从零基础小白到编程高手的详细学习路线攻略
2025年Java学习路线涵盖基础语法、面向对象、数据库、JavaWeb、Spring全家桶、分布式、云原生与高并发技术,结合实战项目与源码分析,助力零基础学员系统掌握Java开发技能,从入门到精通,全面提升竞争力,顺利进阶编程高手。
528 1
|
1月前
|
安全 前端开发 Java
从反射到方法句柄:深入探索Java动态编程的终极解决方案
从反射到方法句柄,Java 动态编程不断演进。方法句柄以强类型、低开销、易优化的特性,解决反射性能差、类型弱、安全性低等问题,结合 `invokedynamic` 成为支撑 Lambda 与动态语言的终极方案。
144 0
|
3月前
|
安全 Java 数据库连接
2025 年最新 Java 学习路线图含实操指南助你高效入门 Java 编程掌握核心技能
2025年最新Java学习路线图,涵盖基础环境搭建、核心特性(如密封类、虚拟线程)、模块化开发、响应式编程、主流框架(Spring Boot 3、Spring Security 6)、数据库操作(JPA + Hibernate 6)及微服务实战,助你掌握企业级开发技能。
552 3
|
2月前
|
Java 开发者
Java并发编程:CountDownLatch实战解析
Java并发编程:CountDownLatch实战解析
431 100
|
2月前
|
算法 Java
Java多线程编程:实现线程间数据共享机制
以上就是Java中几种主要处理多线程序列化资源以及协调各自独立运行但需相互配合以完成任务threads 的技术手段与策略。正确应用上述技术将大大增强你程序稳定性与效率同时也降低bug出现率因此深刻理解每项技术背后理论至关重要.
217 16
|
2月前
|
NoSQL Java 关系型数据库
超全 Java 学习路线,帮你系统掌握编程的超详细 Java 学习路线
本文为超全Java学习路线,涵盖基础语法、面向对象编程、数据结构与算法、多线程、JVM原理、主流框架(如Spring Boot)、数据库(MySQL、Redis)及项目实战等内容,助力从零基础到企业级开发高手的进阶之路。
275 1
|
3月前
|
安全 算法 Java
Java泛型编程:类型安全与擦除机制
Java泛型详解:从基础语法到类型擦除机制,深入解析通配符与PECS原则,探讨运行时类型获取技巧及最佳实践,助你掌握泛型精髓,写出更安全、灵活的代码。
|
3月前
|
安全 Java Shell
Java模块化编程(JPMS)简介与实践
本文全面解析Java 9模块化系统(JPMS),帮助开发者解决JAR地狱、类路径冲突等常见问题,提升代码的封装性、性能与可维护性。内容涵盖模块化核心概念、module-info语法、模块声明、实战迁移、多模块项目构建、高级特性及最佳实践,同时提供常见问题和面试高频题解析,助你掌握Java模块化编程精髓,打造更健壮的应用。