#define MTEST #include using namespace std; #define ALL(x) (x).begin(),(x).end() #define IO ios::sync_with_stdio(false),cin.tie(nullptr); #define REP(i, n) for(ll i=0; i<(ll)(n); i++) #define FOR(i, a, b) for(ll i=(ll)(a); i<(b); i++) #define ROF(i, a, b) for(ll i=(ll)(b)-1; i>=(a); i--) template int LB(const vector& v, T x) { return lower_bound(ALL(v),x)-(v).begin(); } template int UQ(T& v) { sort(ALL(v)); v.erase(unique(ALL(v)),v.end()); return v.size(); } template bool chmax(T &a, T b) { return a bool chmin(T &a, T b) { return a>b ? a=b, true : false; } template using rpriority_queue=priority_queue,greater>; using ll=long long; const int INF=1e9+10; const ll INFL=4e18; using ld=long double; using ull=unsigned long long; using lll=__int128_t; using VST=vector; using VI=vector; using VVI=vector; using VL=vector; using VVL=vector; using PL=pair; using VP=vector; using WG=vector>>; #ifdef LOCAL #include "./debug.hpp" #else #define debug(...) #define print_line #endif void solve(); int main() { IO; int T=1; #ifdef MTEST cin>>T; #endif while(T--) solve(); } /// @brief 二分探索 /// @details 条件 judge を満たす ok と ng の境界を二分探索によって求める。 /// @note O(log(|ok - ng|) * f) template T BinarySearch(T ok, T ng, Judge judge) { while(abs(ok-ng)>1) { T mid=(ok+ng)/2; if(judge(mid)) ok=mid; else ng=mid; } return ok; } /// @brief 回数指定二分探索 /// @details 条件 judge を満たす ok と ng の境界を二分探索によって求める。 /// @note O(iter * f) template T BinarySearchIteration(T ok, T ng, Judge judge, int iter=100) { while(iter--) { T mid=(ok+ng)/2; if(judge(mid)) ok=mid; else ng=mid; } return ok; } /// @brief 単調性の確認 /// @details 関数 judge が単調性を満たすか否かを確認する /// @param start 開始要素 /// @param step 探索幅 /// @param iter 探索回数 template bool CheckMonotonicity(T start, T step, ll iter, Judge judge) { cerr<<"[ "; bool pre=false; ll cnt=0; for(T i=start; iter>0; iter--, i+=step) { bool tmp=judge(i); cerr<<"{ "<>N>>L>>K; VL X(N); REP(i,N) cin>>X[i]; sort(ALL(X)); cout<(L,0, [&](ll m) { REP(i,N) { ll x=X[i],y=X[(i+K)%N]; if(i+K