結果
| 問題 | 
                            No.942 プレゼント配り
                             | 
                    
| コンテスト | |
| ユーザー | 
                             | 
                    
| 提出日時 | 2019-12-06 20:12:44 | 
| 言語 | Python3  (3.13.1 + numpy 2.2.1 + scipy 1.14.1)  | 
                    
| 結果 | 
                             
                                AC
                                 
                             
                            
                         | 
                    
| 実行時間 | 209 ms / 2,000 ms | 
| コード長 | 1,035 bytes | 
| コンパイル時間 | 195 ms | 
| コンパイル使用メモリ | 12,800 KB | 
| 実行使用メモリ | 22,016 KB | 
| 最終ジャッジ日時 | 2024-12-23 16:24:16 | 
| 合計ジャッジ時間 | 3,307 ms | 
| 
                            ジャッジサーバーID (参考情報)  | 
                        judge4 / judge2 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| sample | AC * 2 | 
| other | AC * 18 | 
ソースコード
#!/usr/bin/env python3
def solve(n, k):
    assert n % k == 0
    if n * (n + 1) // 2 % k != 0:
        return None
    if n == 1:
        return [[1]]
    if n // k == 1:
        return None
    z = n * (n + 1) // 2 // k
    a = [[] for _ in range(k)]
    while n // k:
        if n // k == 3:
            for i in range(k):
                a[i] += [n]
                n -= 1
            for i in range(k):
                a[(k // 2 + i) % k] += [n]
                n -= 1
            for i in range(k):
                a[i] += [z - sum(a[i])]
                n -= 1
        else:
            for i in range(k):
                a[i] += [n]
                n -= 1
            for i in range(k):
                a[k - i - 1] += [n]
                n -= 1
    assert len(set(map(sum, a))) == 1
    return a
def main():
    n, k = map(int, input().split())
    answer = solve(n, k)
    if answer:
        print('Yes')
        for it in answer:
            print(*it)
    else:
        print('No')
if __name__ == "__main__":
    main()