D. Minimax Problem(二分+二进制)
You are given nn arrays a1a1, a2a2, ..., anan; each array consists of exactly mm integers. We denote the yy-th element of the xx-th array as ax,yax,y.
You have to choose two arrays aiai and ajaj (1≤i,j≤n1≤i,j≤n, it is possible that i=ji=j). After that, you will obtain a new array bb consisting of mmintegers, such that for every k∈[1,m]k∈[1,m] bk=max(ai,k,aj,k)bk=max(ai,k,aj,k).
Your goal is to choose ii and jj so that the value of mink=1mbkmink=1mbk is maximum possible.
The first line contains two integers nn and mm (1≤n≤3⋅1051≤n≤3⋅105, 1≤m≤81≤m≤8) — the number of arrays and the number of elements in each array, respectively.
Then nn lines follow, the xx-th line contains the array axax represented by mm integers ax,1ax,1, ax,2ax,2, ..., ax,max,m (0≤ax,y≤1090≤ax,y≤109).
Print two integers ii and jj (1≤i,j≤n1≤i,j≤n, it is possible that i=ji=j) — the indices of the two arrays you have to choose so that the value of mink=1mbkmink=1mbk is maximum possible. If there are multiple answers, print any of them.
6 5 5 0 3 1 2 1 8 9 1 3 1 2 3 4 5 9 1 0 3 7 2 3 0 6 3 6 4 1 7 0
1 5
#include<bits/stdc++.h> #include<iostream> #include<cstring> #include<string> #define met(a,x) memset(a,x,sizeof(a)); #define rep(i,a,b) for(ll i = a;i <= b;i++) #define bep(i,a,b) for(ll i = a;i >= b;i--) #define lowbit(x) (x&(-x)) // #define mid ((l + r) >> 1) // #define len (r - l + 1) #define lson l,mid,rt<<1 #define rson mid+1,r,rt<<1|1 #define pb push_back using namespace std; typedef long long ll; ll gcd(ll a, ll b) { return b == 0 ? a : gcd(b, a%b); } ll lcm(ll a, ll b) { return a * b / gcd(a, b); } typedef unsigned long long ull; typedef pair<int, int>Pi; typedef pair<ll, pair<ll, ll> > Pii; const ll inf = 0x3f3f3f3f; const ll INF = 0x3f3f3f3f3f3f3f3f; const double PI = acos(-1); const ll maxn = 1000100; const ll mod = 1000000007; int a[maxn][10]; int n, m,xx,yy; int ok(int x) { int vis[300] = { 0 }; rep(i,1,n){ int now = 0; rep(j,1,m){ if(a[i][j] >= x)now = now*2 + 1; else now = now*2; } vis[now] = i; } rep(i, 0, 255) { rep(j, 0, 255) { if (vis[i] && vis[j] && ((i|j) == ((1 << m) - 1))) { xx = vis[i]; yy = vis[j]; return 1; } } } return 0; } int main() { scanf("%d%d",&n,&m); rep(i, 1, n) { rep(j, 1, m) { scanf("%d",&a[i][j]); } } int l = 0, r = 1e9; while (l <= r) { int mid = (l + r) / 2; if (ok(mid)) l = mid + 1; else r = mid - 1; } cout << xx << ' ' << yy << endl; return 0; }