# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
406681 | 2021-05-18T02:34:29 Z | cpp219 | The Kingdom of JOIOI (JOI17_joioi) | C++14 | 4000 ms | 142224 KB |
#include<bits/stdc++.h> using namespace std; #define ll int #define pb push_back #define pll pair<ll,ll> #define ff first #define ss second #define endl "\n" const ll maxn=2e3+5; const ll base=3e18; const ll mod=1e9+7; const long double eps=1e-10; ll a[maxn][maxn]; ll t[maxn][maxn]; ll pren,prem; ll b[maxn][maxn]; ll n, m; vector<pair<ll,pll>> all; vector<pll> vt; vector<pll> vt1; void xoay() { for (int j=m; j>=1; j--) { for (int i=1; i<=n; i++) { t[m-j+1][i]=a[i][j]; } } for (int i=0; i<vt.size(); i++) { auto p=vt[i]; vt[i]=make_pair(m-p.ss+1,p.ff); } for (int i=0; i<vt1.size(); i++) { auto p=vt1[i]; vt1[i]=make_pair(m-p.ss+1,p.ff); } swap(n,m); for (int i=1; i<=n; i++) { for (int j=1; j<=m; j++) { a[i][j]=t[i][j]; } } } ll mx[maxn]; ll mx1[maxn]; bool chk1() { for (int i=1;i<=m;i++) mx[i]=0; for (auto to:vt) { mx[to.ss]=max(mx[to.ss],to.ff); } mx1[0]=0; for (int i=1;i<=m;i++) { mx1[i]=max(mx1[i-1],mx[i]); } bool chknw=true; for (auto to:vt1) { if (mx1[to.ss]>=to.ff) { return false; chknw=false; break; } } return true; /*if (chknw) return true; mx1[m+1]=0; for (int i=m;i>=1;i--) { mx1[i]=max(mx1[i+1],mx[i]); } chknw=true; for (auto to:vt1) { if (mx1[to.ss]>=to.ff) { return false; } } return true;*/ } void st() { n=pren; m=prem; for (int i=1;i<=n;i++) { for (int j=1;j<=m;j++) a[i][j]=b[i][j]; } } bool chk(ll mid) { vt.clear(); vt1.clear(); ll p=all[0].ff+mid; ll h=all.back().ff-mid; for (auto to:all) { ll cnt=0; if (to.ff>p) vt.pb(to.ss),cnt++; if (to.ff<h) vt1.pb(to.ss),cnt++; if (cnt==2) { return false; } } if (vt.size()==0||vt1.size()==0) { return true; } if (chk1()) { return true; } xoay(); if (chk1()) { st(); return true; } xoay(); if (chk1()) { st(); return true; } xoay(); if (chk1()) { st(); return true; } st(); return false; } int main() { ios_base::sync_with_stdio(false); cin.tie(0); cout.tie(0); if (fopen("t.inp", "r")) { freopen("test.inp", "r", stdin); freopen("test.out", "w", stdout); } cin>> n>> m; pren=n; prem=m; ll mx=0; ll mn=1e9; for (int i=1; i<=n; i++) { for (int j=1; j<=m; j++) { cin>>a[i][j]; b[i][j]=a[i][j]; mx=max(mx,a[i][j]); mn=min(mn,a[i][j]); all.pb(make_pair(a[i][j],make_pair(i,j))); } } sort(all.begin(),all.end()); ll l=0, h=mx-mn; while (l<=h) { ll mid=(l+h)/2; if (chk(mid)) h=mid-1; else l=mid+1; } cout <<l<<endl; }
Compilation message
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 1 ms | 332 KB | Output is correct |
2 | Correct | 1 ms | 332 KB | Output is correct |
3 | Correct | 1 ms | 460 KB | Output is correct |
4 | Correct | 1 ms | 332 KB | Output is correct |
5 | Correct | 1 ms | 460 KB | Output is correct |
6 | Correct | 1 ms | 332 KB | Output is correct |
7 | Correct | 1 ms | 460 KB | Output is correct |
8 | Correct | 1 ms | 460 KB | Output is correct |
9 | Correct | 1 ms | 460 KB | Output is correct |
10 | Correct | 1 ms | 460 KB | Output is correct |
11 | Correct | 1 ms | 460 KB | Output is correct |
12 | Correct | 1 ms | 412 KB | Output is correct |
13 | Correct | 1 ms | 460 KB | Output is correct |
14 | Correct | 1 ms | 460 KB | Output is correct |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 1 ms | 332 KB | Output is correct |
2 | Correct | 1 ms | 332 KB | Output is correct |
3 | Correct | 1 ms | 460 KB | Output is correct |
4 | Correct | 1 ms | 332 KB | Output is correct |
5 | Correct | 1 ms | 460 KB | Output is correct |
6 | Correct | 1 ms | 332 KB | Output is correct |
7 | Correct | 1 ms | 460 KB | Output is correct |
8 | Correct | 1 ms | 460 KB | Output is correct |
9 | Correct | 1 ms | 460 KB | Output is correct |
10 | Correct | 1 ms | 460 KB | Output is correct |
11 | Correct | 1 ms | 460 KB | Output is correct |
12 | Correct | 1 ms | 412 KB | Output is correct |
13 | Correct | 1 ms | 460 KB | Output is correct |
14 | Correct | 1 ms | 460 KB | Output is correct |
15 | Correct | 2 ms | 2124 KB | Output is correct |
16 | Correct | 12 ms | 4168 KB | Output is correct |
17 | Correct | 16 ms | 4296 KB | Output is correct |
18 | Correct | 16 ms | 4276 KB | Output is correct |
19 | Correct | 29 ms | 4292 KB | Output is correct |
20 | Correct | 18 ms | 4040 KB | Output is correct |
21 | Correct | 23 ms | 4300 KB | Output is correct |
22 | Correct | 25 ms | 4276 KB | Output is correct |
23 | Correct | 34 ms | 4296 KB | Output is correct |
24 | Correct | 21 ms | 4040 KB | Output is correct |
25 | Correct | 30 ms | 4296 KB | Output is correct |
26 | Correct | 19 ms | 4236 KB | Output is correct |
27 | Correct | 20 ms | 4296 KB | Output is correct |
28 | Correct | 20 ms | 4296 KB | Output is correct |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 1 ms | 332 KB | Output is correct |
2 | Correct | 1 ms | 332 KB | Output is correct |
3 | Correct | 1 ms | 460 KB | Output is correct |
4 | Correct | 1 ms | 332 KB | Output is correct |
5 | Correct | 1 ms | 460 KB | Output is correct |
6 | Correct | 1 ms | 332 KB | Output is correct |
7 | Correct | 1 ms | 460 KB | Output is correct |
8 | Correct | 1 ms | 460 KB | Output is correct |
9 | Correct | 1 ms | 460 KB | Output is correct |
10 | Correct | 1 ms | 460 KB | Output is correct |
11 | Correct | 1 ms | 460 KB | Output is correct |
12 | Correct | 1 ms | 412 KB | Output is correct |
13 | Correct | 1 ms | 460 KB | Output is correct |
14 | Correct | 1 ms | 460 KB | Output is correct |
15 | Correct | 2 ms | 2124 KB | Output is correct |
16 | Correct | 12 ms | 4168 KB | Output is correct |
17 | Correct | 16 ms | 4296 KB | Output is correct |
18 | Correct | 16 ms | 4276 KB | Output is correct |
19 | Correct | 29 ms | 4292 KB | Output is correct |
20 | Correct | 18 ms | 4040 KB | Output is correct |
21 | Correct | 23 ms | 4300 KB | Output is correct |
22 | Correct | 25 ms | 4276 KB | Output is correct |
23 | Correct | 34 ms | 4296 KB | Output is correct |
24 | Correct | 21 ms | 4040 KB | Output is correct |
25 | Correct | 30 ms | 4296 KB | Output is correct |
26 | Correct | 19 ms | 4236 KB | Output is correct |
27 | Correct | 20 ms | 4296 KB | Output is correct |
28 | Correct | 20 ms | 4296 KB | Output is correct |
29 | Correct | 2866 ms | 137584 KB | Output is correct |
30 | Correct | 3208 ms | 136464 KB | Output is correct |
31 | Correct | 2782 ms | 142112 KB | Output is correct |
32 | Correct | 3396 ms | 142224 KB | Output is correct |
33 | Correct | 1632 ms | 130052 KB | Output is correct |
34 | Correct | 3725 ms | 142056 KB | Output is correct |
35 | Correct | 3500 ms | 142108 KB | Output is correct |
36 | Correct | 3307 ms | 131868 KB | Output is correct |
37 | Execution timed out | 4085 ms | 142128 KB | Time limit exceeded |