当前位置: 首页 > news >正文

经典屏保问题 - 华为OD机试真题(Java 题解)

华为OD机试题库《C++》限时优惠 9.9

华为OD机试题库《Python》限时优惠 9.9

华为OD机试题库《JavaScript》限时优惠 9.9

针对刷题难,效率慢,我们提供一对一算法辅导, 针对个人情况定制化的提高计划(全称1V1效率更高)。

看不懂有疑问需要答疑辅导欢迎私VX: code5bug

华为OD机试真题

题目描述

DVD机在视频输出时,为了保护电视显像管,在待机状态会显示“屏保动画”,如下图所示,DVD Logo在屏幕内来回运动,碰到边缘会反弹。

image-20250731211234020

请根据如下要求,实现屏保Logo坐标的计算算法。

  1. 屏幕是一个800*600像素的矩形,规定屏幕的左上角点坐标原点,沿横边向右方向为X轴,沿竖边向下方向为Y轴
  2. Logo是一个50*25像素的矩形,初始状态下,左上角点坐标记做(x,y),它在X和Y方向上均以1像素/秒的速度开始运动
  3. 遇到屏幕四个边缘后,会发生镜面反弹,即以45°碰撞边缘,再改变方向以45°弹出
  4. 当Logo和四个角碰撞时,两个边缘同时反弹的效果是Logo会原路返回

image-20250731211251185

请编码实现,t秒后Logo左上角点的坐标。

输入描述

输入3个数字,以空格分隔:x y t

第一个数字表示Logo左上角点的初始X坐标; 第二个数字表示Logo左上角点的初始Y坐标; 第三个数字表示时间 t,题目要求即求 t 秒后Logo左上角点的位置。

输出描述

输出2个数字,以空格分隔: x y

第一个数字表示 t 秒后,Logo左上角点的X坐标 第二个数字表示 t 秒后,Logo左上角点的Y坐标

备注

所有用例均保证:

  • 输入的x和y坐标会保证整个Logo都在屏幕范围内,Logo不会出画;
  • 所有输入数据都是合法的数值,且不会出现负数;
  • t 的最大值为100000。

示例1

输入:

0 0 10

输出:

10 10

说明:

输入样例表示Logo初始位置在屏幕的左上角点,10s后,Logo在X和Y方向都移动了10像素,因此输出10 10。

示例2

输入:

500 570 10

输出:

510 570

说明:

输入样例表示初始状态下,Logo的下边缘再有5像素就碰到屏幕下边缘了,5s后,会与屏幕碰撞,碰撞后,斜向45弹出,又经过5s后,Logo与起始位置相比,水平移动了10像素,垂直方向回到了原来的高度。

题解

这道题目属于模拟类问题,主要考察对物体运动轨迹的模拟计算能力。需要根据给定的初始条件和运动规则,计算出经过t秒后的位置。

解题思路

  1. 问题分析:Logo在屏幕内以每秒1像素的速度移动,碰到边缘会反弹。屏幕大小是800x600,Logo大小是50x25。
  2. 关键点
    • Logo碰到左右边缘时(x=0或x+50=800),x方向速度取反
    • Logo碰到上下边缘时(y=0或y+25=600),y方向速度取反
    • 每次移动后检查是否碰到边缘,如果碰到则改变相应方向的速度
  3. 算法选择:直接模拟每一秒的运动过程,更新位置并检查碰撞。

Java

import java.util.Scanner;/*** @author code5bug*/
public class Main {public static void main(String[] args) {Scanner scanner = new Scanner(System.in);int x = scanner.nextInt();int y = scanner.nextInt();int t = scanner.nextInt();int sx = 1, sy = 1; // x和y方向的初始速度while (t-- > 0) {x += sx;y += sy;// 检查是否碰到左右边缘if (x + 50 == 800 || x == 0) sx = -sx;// 检查是否碰到上下边缘if (y + 25 == 600 || y == 0) sy = -sy;}System.out.println(x + " " + y);}
}

希望这个专栏能让您熟练掌握算法, 🎁🎁🎁 。

整理题解不易, 如果有帮助到您,请给点个赞 ‍❤️‍ 和收藏 ⭐,让更多的人看到。🙏🙏🙏

http://www.dtcms.com/a/307692.html

相关文章:

  • uniapp Vue3版本使用pinia存储持久化插件pinia-plugin-persistedstate对微信小程序的配置
  • Django模型迁移指南:从命令用法到最佳实践
  • 分布式微服务--万字详解 微服务的各种负载均衡全场景以注意点
  • Vue3 + Electron 技术栈下 MAC 地址获取的方法、准确性优化与应对策略
  • mac操作笔记
  • nuxt3: trpc-nuxt和sqlite导致的503错误
  • Python 动态属性和特性(使用动态属性转换数据)
  • 【烧脑算法】Dijkstra 算法:解决最短路问题
  • PHP开发
  • SAP Datasphere 02 - 建模
  • 文件无法复制到u盘,提示0x80071ac3错误
  • SpringBoot原理揭秘--自动装配(终)
  • Cesium 快速入门(二)底图更换
  • Spring Cloud『学习笔记』
  • 前端项目如何同时导入一个库的不同版本
  • SpringMVC的核心架构与请求处理流程
  • React中的this绑定
  • 网关 + MDC 过滤器方案,5分钟集成 日志 traceid
  • Java学习-----SpringBoot的常用注解(下)
  • 嵌入式硬件中瓷片电容的基本原理与详解
  • WebRTC 多媒体 SDP 示例与解析
  • 嵌入式硬件学习(十)—— LED驱动+杂项设备驱动
  • 2025电商CPS分销与推客系统小程序开发:趋势、架构与实战解析
  • SpringBoot3.x引入Quartz,持久化到MySQL数据库
  • npm 设置国内镜像源
  • 中宇联:以“智云融合+AI”赋能全栈云MSP服务,深化阿里云生态合作
  • 【YOLOv1】
  • 多云场景实战:华为手机 QR 码绑定与 AWS云服务器终端登录全解
  • 全球SPAD技术发展全景:工艺节点、产能布局与中国突破
  • 科研快报 |无人机+AI:广东防控基孔热背后的技术革命