zoukankan      html  css  js  c++  java
  • Luogu3579 Solar Panels

    整除分块枚举。。。

    真的没有想到会这么简单。

    要使一个数 (p) 满足 条件, 则 存在(x, y)(a<=x imes p<=b && c<=y imes p <=d)

    (p) 除掉 则

       (leftlceildfrac{a}{p} ight ceil <=y <=leftlfloordfrac{b}{p} ight floor)

       (leftlceildfrac{c}{p} ight ceil <=y <=leftlfloordfrac{d}{p} ight floor)

    把向上取整变为向下取整

       (leftlfloordfrac{a+p-1}{p} ight floor <= leftlfloordfrac{b}{p} ight floor)

       (leftlfloordfrac{b+p-1}{p} ight floor <= leftlfloordfrac{d}{p} ight floor)

    然后就变成了 :

      (leftlfloordfrac{a-1}{p} ight floor < leftlfloordfrac{b}{p} ight floor)

      (leftlfloordfrac{b-1}{p} ight floor < leftlfloordfrac{d}{p} ight floor)

    最后整除分块。 只需按照 (b/p)(d/p) 相同时进行分类。 这样能使 (b/p)(d/p)相等的同时 (c/p)(d/p)尽量小, 更可能满足条件

    #include<cstdio>
    #include<cstring>
    #include<algorithm>
    #define rd read()
    #define R register
    using namespace std;
    
    inline int read() {
        int X = 0, p = 1; char c = getchar();
        for (; c > '9' || c < '0'; c =  getchar())
            if (c == '-') p = -1;
        for (; c >= '0' && c <= '9'; c = getchar())
            X = X * 10 + c - '0';
        return X * p;
    }
    
    inline void cmax(int &A, int B) {
        if (A < B) A = B;
    }
    
    inline int cmin(int A, int B) {
        return A > B ? B : A;
    }
    
    void work() {
        int ans = 1;
        int a = rd - 1, b = rd, c = rd - 1, d = rd;
        for (R int i = 1, j = 1, up = cmin(b, d); i <= up; i = j + 1) {
            j = cmin(b / (b / i), d / (d / i));
            if (b / j > a / j && d / j > c / j) cmax(ans, j);
        }
        printf("%d
    ", ans);
    }
    
    int main()
    {
        int n = rd;
        for (; n; --n) work(); 
    }
    
  • 相关阅读:
    银行卡号每隔4位插入空格
    IE6-8下自定义标签的表现
    Sql Server尝试读取或写入受保护的内存。这通常指示其他内存已损坏
    儿童编程教学scratch 3.0
    Shell 教程入门
    自定义vs2005代码段
    解决Adobe ReaderXI自动关闭问题
    WPF——给button添加背景图片
    WPF 异步加载数据
    Caliburn.Micro中的WindowManager
  • 原文地址:https://www.cnblogs.com/cychester/p/9880861.html
Copyright © 2011-2022 走看看