zoukankan      html  css  js  c++  java
  • Codeforces Round #371 (Div. 1) D

    D - Animals and Puzzle

    #include<bits/stdc++.h>
    #define LL long long
    #define fi first
    #define se second
    #define mk make_pair
    #define PII pair<int, int>
    #define PLI pair<LL, int>
    #define ull unsigned long long
    using namespace std;
    
    const int N = 1000 + 7;
    const int inf = 0x3f3f3f3f;
    const LL INF = 0x3f3f3f3f3f3f3f3f;
    const int mod = 1e9 + 7;
    
    int a[N][N], b[N][N], Log[N], n, m;
    
    struct ST2 {
        int dp[N][N][10][10], ty;
        void build(int n, int m, int b[N][N], int _ty) {
            ty = _ty;
            for(int i = 1; i <= n; i++)
                for(int j = 1; j <= m; j++)
                    dp[i][j][0][0] = ty * b[i][j];
            for(int u = 0; u <= Log[n]; u++) {
                for(int v = 0; v <= Log[m]; v++) {
                    if(!u && !v) continue;
                    for(int i = 1; i+(1<<u)-1 <= n; i++) {
                        for(int j = 1; j+(1<<v)-1 <= m; j++) {
                            if(u) dp[i][j][u][v] = max(dp[i][j][u-1][v], dp[i+(1<<(u-1))][j][u-1][v]);
                            else  dp[i][j][u][v] = max(dp[i][j][u][v-1], dp[i][j+(1<<(v-1))][u][v-1]);
                        }
                    }
                }
            }
        }
        int query(int x1, int y1, int x2, int y2) {
            int k1 = Log[x2-x1+1], k2 = Log[y2-y1+1];
            x2 = x2-(1<<k1)+1;
            y2 = y2-(1<<k2)+1;
            return max(max(dp[x1][y1][k1][k2], dp[x2][y1][k1][k2]),
                       max(dp[x1][y2][k1][k2], dp[x2][y2][k1][k2]));
        }
    } rmq;
    
    int main() {
        for(int i = -(Log[0]=-1); i < N; i++)
            Log[i] = Log[i - 1] + ((i & (i - 1)) == 0);
    
        scanf("%d%d", &n, &m);
        for(int i = 1; i <= n; i++)
            for(int j = 1; j <= m; j++)
                scanf("%d", &a[i][j]);
    
        for(int i = n; i >= 1; i--) {
            for(int j = m; j >= 1; j--) {
                if(!a[i][j]) continue;
                b[i][j] = min(b[i+1][j+1], min(b[i][j+1], b[i+1][j])) + 1;
            }
        }
    
        rmq.build(n, m, b, 1);
        int q; scanf("%d", &q);
        while(q--) {
            int x1, y1, x2, y2;
            scanf("%d%d%d%d", &x1, &y1, &x2, &y2);
            int l = 1, r = min(x2-x1, y2-y1) + 1, ans = 0;
            while(l <= r) {
                int mid = l + r >> 1;
                int x3 = x2 - mid + 1, y3 = y2 - mid + 1;
                if(rmq.query(x1, y1, x3, y3) >= mid) l = mid + 1, ans = mid;
                else r = mid - 1;
            }
            printf("%d
    ", ans);
        }
        return 0;
    }
    
    /*
    */
  • 相关阅读:
    PHP识别二维码功能,php-zbarcode 安装
    《架构即未来》读后感(三)
    MVC设计模式案例分析
    SOA
    《架构即未来》读后感(二)
    基于网络拓扑及告警的故障根因定位系统实现及算法研究赛题需求分析
    《架构即未来》读后感(一)
    《大型网站技术架构》读后感(二)
    《一线架构师实践指南》读后感(三)
    《大型网站技术架构》读后感(三)
  • 原文地址:https://www.cnblogs.com/CJLHY/p/9727247.html
Copyright © 2011-2022 走看看