def f(G,s):
q,C,K=[({0},{j for k in G for j in k}-{0},[])],[],[]
for n,u,p in q:
C+=sum(G.get((x,y),0)for x in n for y in u),
for N in n:
for i in G:
if(i[0]==N)>(i in p)<(i[1]!=s)>((T:=sorted(p+[i]))in K):q+=({*n,*i},u-{*i},p+[i]),;K+=T,
return min(C)
def to_edges(m):
return {(x, y):m[x][y] for x in range(len(m))for y in range(len(m[0]))if m[x][y]},len(m)-1
m1 = [[ 0, 20, 0, 50, 0, 0],
[ 0, 0, 40, 10, 0, 0],
[ 0, 0, 0, 0, 25, 25],
[ 0, 0, 45, 0, 30, 0],
[ 0, 0, 0, 0, 0, 50],
[ 0, 0, 0, 0, 0, 0]]
m2 = [[ 0, 10, 17, 0, 0, 0, 0],
[ 0, 0, 0, 2, 13, 0, 0],
[ 0, 5, 0, 0, 4, 8, 0],
[ 0, 0, 0, 0, 0, 0, 20],
[ 0, 0, 0, 18, 0, 0, 0],
[ 0, 0, 0, 0, 1, 0, 7],
[ 0, 0, 0, 0, 0, 0, 0]]
m3 = [[ 0, 6, 2, 7, 4, 0, 0, 0],
[ 0, 0, 0, 0, 0, 10, 0, 0],
[ 0, 8, 0, 0, 0, 0, 9, 4],
[ 0, 0, 11, 0, 0, 0, 0, 0],
[ 0, 0, 0, 5, 0, 0, 0, 0],
[ 0, 0, 13, 0, 0, 0, 0, 16],
[ 0, 0, 0, 14, 0, 0, 0, 12],
[ 0, 0, 0, 0, 0, 0, 0, 0]]
m4 = [[ 0, 40, 50, 0, 0, 0, 0, 0, 0],
[ 0, 0, 0, 30, 10, 0, 0, 0, 0],
[ 0, 0, 0, 40, 0, 0, 10, 0, 0],
[ 0, 0, 0, 0, 15, 10, 0, 0, 0],
[ 0, 0, 0, 0, 0, 0, 0, 0, 20],
[ 0, 0, 0, 0, 0, 0, 15, 20, 0],
[ 0, 0, 0, 0, 0, 0, 0, 30, 0],
[ 0, 0, 0, 0, 0, 0, 0, 0, 50],
[ 0, 0, 0, 0, 0, 0, 0, 0, 0]]
m5 = [[ 0, 5, 8, 3, 3, 7, 0, 0, 0, 7],
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 4],
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 9],
[ 0, 0, 0, 0, 0, 0, 1, 0, 0, 0],
[ 0, 0, 0, 0, 0, 0, 0, 4, 0, 0],
[ 0, 0, 0, 0, 0, 0, 0, 0, 6, 0],
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 1],
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 6],
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 5],
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]]
m6 = [[0, 5],
[0, 0]]
print(f(*to_edges(m1)))
print(f(*to_edges(m2)))
print(f(*to_edges(m3)))
print(f(*to_edges(m4)))
print(f(*to_edges(m5)))
print(f(*to_edges(m6)))
ZGVmIGYoRyxzKToKIHEsQyxLPVsoezB9LHtqIGZvciBrIGluIEcgZm9yIGogaW4ga30tezB9LFtdKV0sW10sW10KIGZvciBuLHUscCBpbiBxOgogIEMrPXN1bShHLmdldCgoeCx5KSwwKWZvciB4IGluIG4gZm9yIHkgaW4gdSksCiAgZm9yIE4gaW4gbjoKICAgZm9yIGkgaW4gRzoKICAgIGlmKGlbMF09PU4pPihpIGluIHApPChpWzFdIT1zKT4oKFQ6PXNvcnRlZChwK1tpXSkpaW4gSyk6cSs9KHsqbiwqaX0sdS17Kml9LHArW2ldKSw7Sys9VCwKIHJldHVybiBtaW4oQykKIApkZWYgdG9fZWRnZXMobSk6CglyZXR1cm4geyh4LCB5KTptW3hdW3ldIGZvciB4IGluIHJhbmdlKGxlbihtKSlmb3IgeSBpbiByYW5nZShsZW4obVswXSkpaWYgbVt4XVt5XX0sbGVuKG0pLTEKCm0xID0gW1sgMCwgMjAsICAwLCA1MCwgIDAsICAwXSwKIFsgMCwgIDAsIDQwLCAxMCwgIDAsICAwXSwKIFsgMCwgIDAsICAwLCAgMCwgMjUsIDI1XSwKIFsgMCwgIDAsIDQ1LCAgMCwgMzAsICAwXSwKIFsgMCwgIDAsICAwLCAgMCwgIDAsIDUwXSwKIFsgMCwgIDAsICAwLCAgMCwgIDAsICAwXV0KCm0yID0gW1sgMCwgMTAsIDE3LCAgMCwgIDAsICAwLCAgMF0sCiBbIDAsICAwLCAgMCwgIDIsIDEzLCAgMCwgIDBdLAogWyAwLCAgNSwgIDAsICAwLCAgNCwgIDgsICAwXSwKIFsgMCwgIDAsICAwLCAgMCwgIDAsICAwLCAyMF0sCiBbIDAsICAwLCAgMCwgMTgsICAwLCAgMCwgIDBdLAogWyAwLCAgMCwgIDAsICAwLCAgMSwgIDAsICA3XSwKIFsgMCwgIDAsICAwLCAgMCwgIDAsICAwLCAgMF1dCgptMyA9IFtbIDAsICA2LCAgMiwgIDcsICA0LCAgMCwgIDAsICAwXSwKIFsgMCwgIDAsICAwLCAgMCwgIDAsIDEwLCAgMCwgIDBdLAogWyAwLCAgOCwgIDAsICAwLCAgMCwgIDAsICA5LCAgNF0sCiBbIDAsICAwLCAxMSwgIDAsICAwLCAgMCwgIDAsICAwXSwKIFsgMCwgIDAsICAwLCAgNSwgIDAsICAwLCAgMCwgIDBdLAogWyAwLCAgMCwgMTMsICAwLCAgMCwgIDAsICAwLCAxNl0sCiBbIDAsICAwLCAgMCwgMTQsICAwLCAgMCwgIDAsIDEyXSwKIFsgMCwgIDAsICAwLCAgMCwgIDAsICAwLCAgMCwgIDBdXQoKbTQgPSBbWyAwLCA0MCwgNTAsICAwLCAgMCwgIDAsICAwLCAgMCwgIDBdLAogWyAwLCAgMCwgIDAsIDMwLCAxMCwgIDAsICAwLCAgMCwgIDBdLAogWyAwLCAgMCwgIDAsIDQwLCAgMCwgIDAsIDEwLCAgMCwgIDBdLAogWyAwLCAgMCwgIDAsICAwLCAxNSwgMTAsICAwLCAgMCwgIDBdLAogWyAwLCAgMCwgIDAsICAwLCAgMCwgIDAsICAwLCAgMCwgMjBdLAogWyAwLCAgMCwgIDAsICAwLCAgMCwgIDAsIDE1LCAyMCwgIDBdLAogWyAwLCAgMCwgIDAsICAwLCAgMCwgIDAsICAwLCAzMCwgIDBdLAogWyAwLCAgMCwgIDAsICAwLCAgMCwgIDAsICAwLCAgMCwgNTBdLAogWyAwLCAgMCwgIDAsICAwLCAgMCwgIDAsICAwLCAgMCwgIDBdXQoKbTUgPSBbWyAwLCA1LCA4LCAzLCAzLCA3LCAwLCAwLCAwLCA3XSwKIFsgMCwgMCwgMCwgMCwgMCwgMCwgMCwgMCwgMCwgNF0sCiBbIDAsIDAsIDAsIDAsIDAsIDAsIDAsIDAsIDAsIDldLAogWyAwLCAwLCAwLCAwLCAwLCAwLCAxLCAwLCAwLCAwXSwKIFsgMCwgMCwgMCwgMCwgMCwgMCwgMCwgNCwgMCwgMF0sCiBbIDAsIDAsIDAsIDAsIDAsIDAsIDAsIDAsIDYsIDBdLAogWyAwLCAwLCAwLCAwLCAwLCAwLCAwLCAwLCAwLCAxXSwKIFsgMCwgMCwgMCwgMCwgMCwgMCwgMCwgMCwgMCwgNl0sCiBbIDAsIDAsIDAsIDAsIDAsIDAsIDAsIDAsIDAsIDVdLAogWyAwLCAwLCAwLCAwLCAwLCAwLCAwLCAwLCAwLCAwXV0KCm02ID0gW1swLCA1XSwKIFswLCAwXV0KCnByaW50KGYoKnRvX2VkZ2VzKG0xKSkpCnByaW50KGYoKnRvX2VkZ2VzKG0yKSkpCnByaW50KGYoKnRvX2VkZ2VzKG0zKSkpCnByaW50KGYoKnRvX2VkZ2VzKG00KSkpCnByaW50KGYoKnRvX2VkZ2VzKG01KSkpCnByaW50KGYoKnRvX2VkZ2VzKG02KSkp