• 【Leetcode】1362. Closest Divisors(配数学证明)


    题目地址:

    https://leetcode.com/problems/closest-divisors/

    给定一个正整数 x x x,要求找到 a , b a,b a,b满足 a b = x + 1 ∨ a b = x + 2 ab=x+1\lor ab=x+2 ab=x+1ab=x+2,并且使得 ∣ a − b ∣ |a-b| ab尽可能小。

    可以证明解是唯一的。不妨设 a 1 ≤ b 1 , a 2 ≤ b 2 a_1\le b_1,a_2\le b_2 a1b1,a2b2如果 a 1 b 1 = x + 1 , a 2 b 2 = x + 2 a_1b_1=x+1,a_2b_2=x+2 a1b1=x+1,a2b2=x+2并且 b 1 − a 1 = b 2 − a 2 b_1-a_1=b_2-a_2 b1a1=b2a2,那么 a 2 − a 1 = b 2 − b 1 a_2-a_1=b_2-b_1 a2a1=b2b1,则 a 2 b 2 ≥ ( a 1 + 1 ) ( b 1 + 1 ) = a 1 b 1 + a 1 + b 1 + 1 ≥ a 1 b 1 + 3 = x + 4 a_2b_2\ge (a_1+1)(b_1+1)=a_1b_1+a_1+b_1+1\ge a_1b_1+3=x+4 a2b2(a1+1)(b1+1)=a1b1+a1+b1+1a1b1+3=x+4,矛盾。

    接着从 x + 2 → 1 \sqrt {x+2}\to 1 x+2 1遍历,枚举 a a a,如果发现 a ∣ ( x + 1 ) a|(x+1) a(x+1)或者 a ∣ ( x + 2 ) a|(x+2) a(x+2),则找到了一组解。这个解就是最优解。因为 ( x + 1 , x + 2 ) = 1 (x+1,x+2)=1 (x+1,x+2)=1,所以上面的两个整除式子不能同时成立。如果发现 a 1 b 1 = x + 1 , a 2 b 2 = x + 2 , a 2 < a 1 a_1b_1=x+1,a_2b_2=x+2,a_2a1b1=x+1,a2b2=x+2,a2<a1,由于 a 2 b 2 > a 1 b 1 a_2b_2>a_1b_1 a2b2>a1b1所以 b 2 > b 1 b_2>b_1 b2>b1,矛盾;如果发现 a 1 b 1 = x + 2 , a 2 b 2 = x + 1 , a 2 < a 1 a_1b_1=x+2,a_2b_2=x+1,a_2a1b1=x+2,a2b2=x+1,a2<a1,如果 b 2 < b 1 b_2b2<b1,则 a 1 b 1 = x + 2 ≥ ( a 2 + 1 ) ( b 2 + 1 ) ≥ x + 4 a_1b_1=x+2\ge (a_2+1)(b_2+1)\ge x+4 a1b1=x+2(a2+1)(b2+1)x+4矛盾。

    代码如下:

    class Solution {
     public:
      vector<int> closestDivisors(int num) {
        for (int x = sqrt(num + 2); x; x--) {
          if ((num + 1) % x == 0) return {x, (num + 1) / x};
          if ((num + 2) % x == 0) return {x, (num + 2) / x};
        }
    
        return {};
      }
    };
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    时间复杂度 O ( x ) O(\sqrt x) O(x ),空间 O ( 1 ) O(1) O(1)

  • 相关阅读:
    树和森林知识
    c 摄像头生成yuv未压缩图片
    一个不错的开源项目风控引擎(Radar)
    构造函数、类成员、析构函数调用顺序
    [附源码]SSM计算机毕业设计在线购物系统JAVA
    Spring Boot与Web开发-快速开发CRUD
    为全志T507-H开发板配置Samba服务,高效实现跨系统的文件共享
    使用IDEA开发JavaWeb项目的基本配置最新教程
    muduo源码剖析之Buffer缓冲区类
    停车场智能化管理系统
  • 原文地址:https://blog.csdn.net/qq_46105170/article/details/126743444