【蓝桥杯3510】冶炼金属(区间&java)

问题描述

答案提交

解题思路

起初看到题的时候还在想着把75 3,53 2,59 2这样的对给存起来,然后用i一个一个试出来。

后来发现有更巧妙的方法,就是每一个对都会得到一个范围,那么只要求得所有范围的交集就是答案了。有种四两拨千斤的感觉。

AC代码

import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);

        // 读取输入的整数 n
        int n = scan.nextInt();

        // 初始化左右边界
        int left = 0, right = 1000000000;

        // 循环 n 次,读取每对整数 a 和 b
        while (n-- > 0) {
            int a = scan.nextInt();
            int b = scan.nextInt();

            // 计算 c 和 d 的值
            int c = a / (b + 1) + 1;
            int d = a / b;

            // 更新左边界,如果 c 大于当前左边界
            if (c > left) {
                left = c;
            }

            // 更新右边界,如果 d 小于当前右边界
            if (d < right) {
                right = d;
            }
        }

        // 输出结果
        System.out.println(left + " " + right);
    }
}

相关知识 

思维,问题转化,区间

(by 归忆)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

归忆_AC

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值