結果

問題 No.1345 Beautiful BINGO
ユーザー titia
提出日時 2021-01-18 09:07:13
言語 PyPy3
(7.3.15)
結果
AC  
実行時間 1,758 ms / 2,000 ms
コード長 959 bytes
コンパイル時間 850 ms
コンパイル使用メモリ 82,312 KB
実行使用メモリ 76,960 KB
最終ジャッジ日時 2024-11-30 19:30:59
合計ジャッジ時間 21,105 ms
ジャッジサーバーID
(参考情報)
judge5 / judge2
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 2
other AC * 61
権限があれば一括ダウンロードができます

ソースコード

diff #

import sys
input = sys.stdin.readline

N,M=map(int,input().split())
A=[]
for i in range(N):
    A.extend(list(map(int,input().split())))

ANS=1<<30
for i in range(1<<(N+2)):
    
    x=0
    for j in range(N+2):
        if (1<<j) & i !=0:
            x+=1

    r=M-x

    if r<0 or r>N:
        continue

    B=[0]*(N*N)

    for j in range(N+2):
        if (1<<j) & i != 0:
            if j<N:
                for k in range(N):
                    B[k*N+j]=1
            elif j==N:
                for k in range(N):
                    B[k*N+k]=1
            else:
                for k in range(N):
                    B[k*N+N-k-1]=1

    SCORE=0
    C=[]

    for j in range(N):
        sc=0
        for k in range(N):
            if B[j*N+k]==1:
                SCORE+=A[j*N+k]
            else:
                sc+=A[j*N+k]
        C.append(sc)

    C.sort()

    ANS=min(ANS,SCORE+sum(C[:r]))

print(ANS)
    
            
            

    
        
0