Cod sursa(job #1514593)

Utilizator akaprosAna Kapros akapros Data 31 octombrie 2015 12:48:00
Problema Plantatie Scor 0
Compilator cpp Status done
Runda Arhiva de probleme Marime 1.09 kb
#include <cstdio>
#include <cstring>
#include <algorithm>
#define maxN 502
#define maxL 100
using namespace std;
int n, i, j, k, m, d[maxL][maxN][maxN], p, Log[maxN];
void read()
{
    freopen("plantatie.in", "r", stdin);
    scanf("%d %d", &n, &m);
    for (i = 1; i <= n; ++ i)
    for (j = 1; j <= n; ++ j)
    scanf("%d", &d[0][i][j]);

    for (i = 2; i <= n; ++ i)
        Log[i] = Log[i / 2] + 1;
}
void solve()
{
    for (k = 1; 1 << k <= n; ++ k)
        for (i = 1; i <= n; ++ i)
            for (j = 1; j <= n; ++ j)
                if ( i + (1 << k) - 1 <= n && j + (1 << k) - 1 <= n)
                {
                    p = 1 << (k - 1);
                    d[k][i][j] = max(max(d[k - 1][i][j], d[k - 1][i + p][j + p]), max(d[k - 1][i][j + p], d[k - 1][i + p][j]));
                }
}
void write()
{
    int x, y, sol;
    freopen("plantatie.out", "w", stdout);
    while (m --)
    {
        scanf("%d %d %d", &x, &y, &k);
        sol = max(d[p][x][y], d[p][x - (1 << p) + 1][y - (1 << p) + 1]);
        printf("%d\n", sol);
    }
}
int main()
{
    read();
    solve();
    write();
    return 0;
}