题解:监控屏幕调整问题

问题描述

Reca 公司生产高端显示器,其中最受欢迎的型号是 AB999。屏幕尺寸为 x \\times y 的比例。由于某些生产特性,屏幕参数总是整数。最终,屏幕边长比例 x:y 需要适应用户的需求。

为了满足用户需求,公司需要调整屏幕尺寸,使其满足以下条件:

  1. 屏幕能够完整容纳在用户给定的宽高限制 a \\times b 内;
  2. 调整后屏幕的宽高比必须等于 x:y
  3. 调整后的屏幕尺寸尽可能接近用户提供的最大边界 a \\times b

如果无法满足以上条件,则输出 0 0


输入格式

输入包含一行,四个整数 a, b, x, y,分别表示:

  • 用户提供的屏幕宽高限制:ab
  • 屏幕宽高比:x:y

限制条件

  • 1 \\leq a, b, x, y \\leq 2 \\times 10\^9

输出格式

如果存在满足条件的调整尺寸,输出两个整数,分别表示屏幕的宽和高。如果无法满足条件,则输出 0 0


示例

示例 1

输入:

复制代码
800 600 4 3

输出:

复制代码
800 600

解释:

  • 屏幕比例为 4:3,可以直接容纳在 800 \\times 600 内,输出原始尺寸。

示例 2

输入:

复制代码
1920 1200 16 9

输出:

复制代码
1920 1080

解释:

  • 按照比例 16:9,调整后的屏幕最大尺寸为 1920 \\times 1080,符合限制条件。

示例 3

输入:

复制代码
1 1 1 2

输出:

复制代码
0 0

解释:

  • 不可能调整出宽高比为 1:2 且小于等于 1 \\times 1 的屏幕。

Python代码实现

以下是问题的 Python 实现代码:

复制代码
def gcd(x, y):
    """计算两个数的最大公约数"""
    return y if x == 0 else gcd(y % x, x)

def main():
    # 读取输入
    a, b, x, y = map(int, input().split())
    
    # 计算 x 和 y 的最大公约数,约分比例
    g = gcd(x, y)
    x //= g
    y //= g

    # 计算缩放比例
    u = a // x
    v = b // y
    factor = min(u, v)

    # 判断是否可行
    if factor > 0:
        print(factor * x, factor * y)
    else:
        print(0, 0)

if __name__ == "__main__":
    main()

代码详解

  1. 最大公约数函数 (gcd)

    • 使用递归方式计算两个数的最大公约数,确保比例 x:y 化简为最简分数。
  2. 输入处理

    • 使用 map(int, input().split()) 读取用户提供的宽高限制 a, b 以及比例 x, y
  3. 比例化简

    • xy 分别除以它们的最大公约数 g,得到最简分数形式。
  4. 计算缩放比例

    • 计算分别可容纳的倍数:
      • u = a // x 表示 a 中可以容纳的宽度倍数;
      • v = b // y 表示 b 中可以容纳的高度倍数。
    • 选择最小的倍数作为最终缩放因子 factor = min(u, v)
  5. 结果判断与输出

    • 如果 factor > 0,输出调整后的屏幕尺寸;
    • 否则,输出 0 0

示例测试

示例 1

输入:

复制代码
800 600 4 3

输出:

复制代码
800 600

解释:

  • 屏幕比例为 4:3,可以直接容纳在 800 \\times 600 内,输出原始尺寸。

示例 2

输入:

复制代码
1920 1200 16 9

输出:

复制代码
1920 1080

解释:

  • 按照比例 16:9,调整后的屏幕最大尺寸为 1920 \\times 1080,符合限制条件。

示例 3

输入:

复制代码
1 1 1 2

输出:

复制代码
0 0

解释:

  • 不可能调整出宽高比为 1:2 且小于等于 1 \\times 1 的屏幕。

实际应用场景

  1. 分辨率优化

    • 在显示设备中,需要根据用户提供的边界限制计算最优的显示分辨率。
    • 应用场景如投影仪、屏幕调整等。
  2. 视频裁剪

    • 在视频剪辑中,需要调整视频画面的宽高比以适配不同的显示器。
  3. 工业设计

    • 用于计算工业设备中,如何最大化利用有限空间展示屏幕内容。

总结

这道题目考察了数学中的比例与最大公约数的基本应用,同时结合实际应用场景(显示器分辨率调整),非常贴近实际问题。通过简洁的代码实现,可以在 O(\\log(\\min(x, y))) 的时间复杂度内解决问题。

希望这篇文章能对你有所帮助!如果喜欢,记得点赞支持哦 😊~


相关推荐
程序员小寒7 分钟前
前端性能优化之白屏、卡顿指标和网络环境采集篇
前端·javascript·网络·性能优化
一叶落4389 分钟前
题目:15. 三数之和
c语言·数据结构·算法·leetcode
烛阴35 分钟前
Claude CLI AskUserQuestion 工具详解:让 AI 开口问你
前端·claude
带娃的IT创业者35 分钟前
WeClaw 离线消息队列实战:异步任务队列如何保证在服务器宕机时不丢失任何一条 AI 回复?
运维·服务器·人工智能·python·websocket·fastapi·实时通信
wal13145201 小时前
OpenClaw教程(九)—— 彻底告别!OpenClaw 卸载不残留指南
前端·网络·人工智能·chrome·安全·openclaw
老鱼说AI1 小时前
CUDA架构与高性能程序设计:异构数据并行计算
开发语言·c++·人工智能·算法·架构·cuda
mon_star°1 小时前
在TypeScript中,接口MenuItem定义中,为什么有的属性带问号?,有的不带呢?
前端
牛奶1 小时前
分享一个开源项目,让 AI 辅助开发真正高效起来
前端·人工智能·全栈
罗湖老棍子2 小时前
【例 1】数列操作(信息学奥赛一本通- P1535)
数据结构·算法·树状数组·单点修改 区间查询