#include "bits/stdc++.h"
using namespace std;
#define f first
#define lgn 25
#define endl '\n'
#define sc second
#define N (int)2e5+5
#define sz(x) x.size()
#define int long long int
#define ld long double
#define vi vector<int>
#define vs vector<string>
#define vc vector<char>
#define mii map<int,int>
#define pii pair<int,int>
#define vpii vector<pii>
#define test(x) while(x--)
#define pb push_back
#define eb emplace_back
#define pq priority_queue
#define mod 1000000007
#define fo(i,a,n) for(int i=a;i<n;i++)
#define rfo(i,n,a) for(int i=n;i>=a;i--)
#define mst(a,v,n) fo(i,0,n) a[i]=v
#define all(x) begin(x),end(x)
#define allr(x) rbegin(x),rend(x)
#define rev(x) reverse(begin(x),end(x))
#define db(x) cout<<#x <<" : "<< x <<endl;
#define time() cerr << "Time : " << (double)clock() / (double)CLOCKS_PER_SEC << "s\n"
const int inf = 0x3f3f3f3f;
const int INF = 0x3f3f3f3f3f3f3f3f;
int n,m,q,k;
vi adj[N];
pq <int,vi,less<int> > pp; // Max Heap
int dis(int x,int y)
{
return x*x + y*y;
}
void go()
{
cin>>q>>k;
fo(i,0,q)
{
int ch,x,y;
cin>>ch;
if(ch==1)
{
cin>>x>>y;
int distance=dis(x,y);
pp.push(distance);
if(sz(pp) > k) pp.pop(); // if size of queue is greater than k , remove the topmost element
}
else
{
cout<<pp.top()<<endl; // topmost element in queue is the kth nearest
}
}
}
int32_t main()
{
ios::sync_with_stdio(0); cin.tie(0); cout.tie(0);
int t=1;
// cin>>t;
test(t) go();
}
I2luY2x1ZGUgImJpdHMvc3RkYysrLmgiCgp1c2luZyBuYW1lc3BhY2Ugc3RkOwoKI2RlZmluZSAgZiBmaXJzdAojZGVmaW5lICBsZ24gMjUKI2RlZmluZSAgZW5kbCAnXG4nCiNkZWZpbmUgIHNjIHNlY29uZAojZGVmaW5lICBOIChpbnQpMmU1KzUKI2RlZmluZSAgc3ooeCkgeC5zaXplKCkKI2RlZmluZSAgaW50IGxvbmcgbG9uZyBpbnQKI2RlZmluZSAgbGQgbG9uZyBkb3VibGUKI2RlZmluZSAgdmkgdmVjdG9yPGludD4KI2RlZmluZSAgdnMgdmVjdG9yPHN0cmluZz4KI2RlZmluZSAgdmMgdmVjdG9yPGNoYXI+CiNkZWZpbmUgIG1paSBtYXA8aW50LGludD4KI2RlZmluZSAgcGlpIHBhaXI8aW50LGludD4KI2RlZmluZSAgdnBpaSB2ZWN0b3I8cGlpPgojZGVmaW5lICB0ZXN0KHgpIHdoaWxlKHgtLSkKI2RlZmluZSAgcGIgcHVzaF9iYWNrCiNkZWZpbmUgIGViIGVtcGxhY2VfYmFjawojZGVmaW5lICBwcSBwcmlvcml0eV9xdWV1ZQojZGVmaW5lICBtb2QgMTAwMDAwMDAwNwojZGVmaW5lICBmbyhpLGEsbikgZm9yKGludCBpPWE7aTxuO2krKykKI2RlZmluZSAgcmZvKGksbixhKSBmb3IoaW50IGk9bjtpPj1hO2ktLSkKI2RlZmluZSAgbXN0KGEsdixuKSBmbyhpLDAsbikgYVtpXT12CiNkZWZpbmUgIGFsbCh4KSBiZWdpbih4KSxlbmQoeCkKI2RlZmluZSAgYWxscih4KSByYmVnaW4oeCkscmVuZCh4KQojZGVmaW5lICByZXYoeCkgcmV2ZXJzZShiZWdpbih4KSxlbmQoeCkpCiNkZWZpbmUgIGRiKHgpIGNvdXQ8PCN4IDw8IiA6ICI8PCB4IDw8ZW5kbDsKI2RlZmluZSB0aW1lKCkgY2VyciA8PCAiVGltZSA6ICIgPDwgKGRvdWJsZSljbG9jaygpIC8gKGRvdWJsZSlDTE9DS1NfUEVSX1NFQyA8PCAic1xuIgoKY29uc3QgaW50IGluZiA9IDB4M2YzZjNmM2Y7CmNvbnN0IGludCBJTkYgPSAweDNmM2YzZjNmM2YzZjNmM2Y7CgppbnQgbixtLHEsazsKdmkgYWRqW05dOwpwcSA8aW50LHZpLGxlc3M8aW50PiA+IHBwOyAvLyBNYXggSGVhcAoKaW50IGRpcyhpbnQgeCxpbnQgeSkKewogICAgcmV0dXJuIHgqeCArIHkqeTsKfQp2b2lkIGdvKCkKewogICAgY2luPj5xPj5rOwogICAgZm8oaSwwLHEpCiAgICB7CiAgICAgICAgaW50IGNoLHgseTsKICAgICAgICBjaW4+PmNoOwogICAgICAgIGlmKGNoPT0xKQogICAgICAgIHsKICAgICAgICAgICAgY2luPj54Pj55OwogICAgICAgICAgICBpbnQgZGlzdGFuY2U9ZGlzKHgseSk7CiAgICAgICAgICAgIHBwLnB1c2goZGlzdGFuY2UpOwogICAgICAgICAgICBpZihzeihwcCkgPiBrKSBwcC5wb3AoKTsgLy8gaWYgc2l6ZSBvZiBxdWV1ZSBpcyBncmVhdGVyIHRoYW4gayAsIHJlbW92ZSB0aGUgdG9wbW9zdCBlbGVtZW50CiAgICAgICAgfQogICAgICAgIGVsc2UKICAgICAgICB7CiAgICAgICAgICAgY291dDw8cHAudG9wKCk8PGVuZGw7IC8vIHRvcG1vc3QgZWxlbWVudCBpbiBxdWV1ZSBpcyB0aGUga3RoIG5lYXJlc3QgCgogICAgICAgIH0KICAgIH0KCgp9CgppbnQzMl90IG1haW4oKQp7CiAgICBpb3M6OnN5bmNfd2l0aF9zdGRpbygwKTsgY2luLnRpZSgwKTsgY291dC50aWUoMCk7CiAgICBpbnQgdD0xOyAKICAgIC8vIGNpbj4+dDsKICAgIHRlc3QodCkgZ28oKTsKfQ==