作者主页:Designer 小郑
作者简介:软件工程师一枚,来自浙江宁波,负责开发管理公司OA项目,专注软件前后端开发(Vue、SpringBoot和微信小程序)、系统定制、远程技术指导。CSDN学院、蓝桥云课认证讲师,全栈领域优质创作者,在校期间参加PAT乙级考试获得满分,三年ACM竞赛经验,斩获国奖两项,省奖五项。热爱技术、专注业务、开放合作、乐于分享,期待你我共同成长!
主打方向:Vue、SpringBoot、微信小程序

题目链接:题目链接

题面:

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

这个 ”自由弹簧“ 在初次使用时,会将小王弹射到 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)),从而通过本题。

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

  1. 华硕编程竞赛11月JAVA专场 C题太空遨游 题解

    作者主页:Designer 小郑 作者简介:Java全栈软件工程师一枚,来自浙江宁波,负责开发管理公司OA项目,专注软件前后端开发(Vue.SpringBoot和微信小程序).系统定制.远程技术指导. ...

  2. 华硕编程竞赛11月JAVA专场 G题飞行棋 题解

    作者主页:Designer 小郑 作者简介:Java全栈软件工程师一枚,来自浙江宁波,负责开发管理公司OA项目,专注软件前后端开发(Vue.SpringBoot和微信小程序).系统定制.远程技术指导. ...

  3. 华硕编程竞赛11月JAVA专场 D题飞机大战 题解

    作者主页:Designer 小郑 作者简介:Java全栈软件工程师一枚,来自浙江宁波,负责开发管理公司OA项目,专注软件前后端开发(Vue.SpringBoot和微信小程序).系统定制.远程技术指导. ...

  4. 华硕编程竞赛11月JAVA专场 B题召唤精灵 题解

    作者主页:Designer 小郑 作者简介:软件工程师一枚,来自浙江宁波,负责开发管理公司OA项目,专注软件前后端开发(Vue.SpringBoot和微信小程序).系统定制.远程技术指导.CSDN学院 ...

  5. 华硕编程竞赛11月JAVA专场 J题再见天空 题解

    作者主页:Designer 小郑 作者简介:Java全栈软件工程师一枚,来自浙江宁波,负责开发管理公司OA项目,专注软件前后端开发(Vue.SpringBoot和微信小程序).系统定制.远程技术指导. ...

  6. 关于517编程的11月月赛

    关于517编程的11月月赛-Nov.29 by Jasonxu 我是传送门 T1:umin之和 1.1题目 小海狸定义 umin为最小的没有在子集中出现过的非负整数. 小海狸有一组非负整数,他希望将这 ...

  7. 2020年11月软件设计师真题透析

    2020年下半年软件设计师上午真题及答案解析 1.在程序执行过程中,高速缓存(Cache)  与主存间的地址映射由(   ). A. 操作系统进行管理 B. 操作系统进行管理 C.    程序员自行安 ...

  8. 【系统集成项目管理工程师】2021年11月上午+下午真题及答案解析

    软考大讲堂2021年下半年系统集成项目管理工程师真题答案已经发布!帮助大家在线免费估分,"提前"知晓分数! 2021年11月系统集成项目管理工程师 上午题 1.2020 年 4 月 ...

  9. 2022年5月、11月网络工程师真题详解

    请点击↑关注.收藏,本博客免费为你获取精彩知识分享!有惊喜哟!! 2022年5月网络工程师科目二真题 试题一: 某分支机构网络拓扑图如 1-1 所示,该网络通过 BGP 接收总部网络路由,设备 1 与 ...

最新文章

  1. Windows任务管理器 explorer 进程
  2. 边工作边考研的计算机经验,边工作边考研的经验
  3. 运营商主动关闭WLAN热点背后:关键是找准产业位置
  4. Spring Boot笔记-@Qualifier与@Autowired与@Bean
  5. 【消息队列之rabbitmq】Rabbitmq之消息可靠性投递和ACK机制实战
  6. area标签高亮_HTML的所有标签列表
  7. 成功破解某app加密接口
  8. 【面试题】「2023」JavaScript 最新高频 前端面试题 指南 (必看)
  9. [WPF]图片裁切功能(鼠标绘制)
  10. C语言逻辑门运算示例
  11. 电子科技大学计算机专业考什么,2015年电子科技大学081203计算机应用技术考研专业目录及考试科目...
  12. 2020版熊猫金币解读及购买方式
  13. 为弹性云服务器申请和绑定弹性公网IP
  14. Invalid component name Component names should conform to valid custom element name报错
  15. php之Twitter第三方登录
  16. 真实评测:华为nova8和红米k30至尊版哪个好-参数区别对比
  17. LateX使用笔记(持续更新)
  18. 张勋说:棒磨机钢棒直径的配置(热处理调质耐磨钢棒)
  19. 找优秀项目很好的网站推荐
  20. 5G新基建到来,图扑推出智慧路灯三维可视化方案

热门文章

  1. 孔子最得意的弟子颜回不幸英年早逝
  2. 【数学建模入门】整数规划求最优解|分枝定界法求最优解
  3. 计算机网络原理笔记 第三章 数据链路层(一)
  4. 【Python爬虫实战】用urllib与服务端交互(发送和接收数据)
  5. electron实现远程更新
  6. 《实用软件架构:从系统环境到软件部署 》——导读
  7. grep(模式匹配器)详解
  8. 历届奥斯卡最佳影片(1928-2003)
  9. 3D视觉缺陷检测:理论与实战!
  10. React 官网入门教程 - 井字棋小游戏