結果
問題 | No.2567 A_1 > A_2 > ... > A_N |
ユーザー | mymelochan |
提出日時 | 2023-12-02 16:00:11 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 1,311 ms / 2,000 ms |
コード長 | 1,034 bytes |
コンパイル時間 | 280 ms |
コンパイル使用メモリ | 82,176 KB |
実行使用メモリ | 96,384 KB |
最終ジャッジ日時 | 2024-09-26 19:39:46 |
合計ジャッジ時間 | 10,375 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 1 |
other | AC * 16 |
ソースコード
############################################################# import sys sys.setrecursionlimit(10**7) from heapq import heappop,heappush from collections import deque,defaultdict,Counter from bisect import bisect_left, bisect_right from itertools import product,combinations,permutations from math import sin,cos #from math import isqrt #DO NOT USE PyPy ipt = sys.stdin.readline iin = lambda :int(ipt()) lmin = lambda :list(map(int,ipt().split())) ############################################################# for _ in range(iin()): N,X = lmin() if N*(N+1)//2 > X: print(-1) continue ans = [] v = 1<<60 rem = X for i in range(N-1): ok = v ng = N-1-i r = N-i while ok-ng > 1: cen = (ok+ng)//2 if (cen+1)*cen//2 - (cen-r+1)*(cen-r)//2 >= rem: ok = cen else: ng = cen v = ok-1 ans.append(ok) #print("a",ok,rem) rem -= ok ans.append(rem) print(*ans)