結果
| 問題 | No.2493 K-th in L2 with L1 | 
| コンテスト | |
| ユーザー |  june19312 | 
| 提出日時 | 2023-10-06 21:48:36 | 
| 言語 | PyPy3 (7.3.15) | 
| 結果 | 
                                AC
                                 
                             | 
| 実行時間 | 133 ms / 2,000 ms | 
| コード長 | 919 bytes | 
| コンパイル時間 | 399 ms | 
| コンパイル使用メモリ | 82,304 KB | 
| 実行使用メモリ | 82,000 KB | 
| 最終ジャッジ日時 | 2024-07-26 15:58:36 | 
| 合計ジャッジ時間 | 1,700 ms | 
| ジャッジサーバーID (参考情報) | judge2 / judge5 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| sample | AC * 1 | 
| other | AC * 4 | 
ソースコード
Q = int(input())
za1 = []
za2 = []
for i in range(-100,101):
    for j in range(-100,101):
        ma = abs(i)+abs(j)
        yu = i**2 + j**2
        za1.append([ma,yu,i,j])
za1.sort()
#print(za1[:20])
for i in range(Q):
    D,K = map(int,input().split())
    if za1[0][0] == D:
        if za1[0+K-1][0] == D:
            print("Yes")
            print(*[za1[0+K-1][2],za1[0+K-1][3]])
        else:
            print("No")
    else:
        if za1[-1][0] < D:
            print("No")
        else:
            ng,ok = 0,len(za1)-1
            while abs(ok-ng)>1:
                mid = abs((ok+ng)//2)
                
                if za1[mid][0] < D:
                    ng = mid
                else:
                    ok = mid
            if za1[ok+K-1][0] == D:
                print("Yes")
                print(*[za1[ok+K-1][2],za1[ok+K-1][3]])
            else:
                print("No")
            
            
            
            
        