#38288: python 紀錄 並查集


BensonDC (python戰士)

學校 : 不指定學校
編號 : 240921
來源 : [163.32.78.214]
最後登入時間 :
2024-11-06 14:27:58
m372. 3. 搬家 -- 2023年10月APCS | From: [1.175.211.7] | 發表日期 : 2023-11-10 10:35

directions=[(-1,0),(0,-1)] # 上左
dL={
    'X':[(1,0),(-1,0),(0,1),(0,-1)],# 下上右左
    'I':[(1,0),(-1,0)],
    'H':[(0,1),(0,-1)],
    'L':[(-1,0),(0,1)],
    '7':[(1,0),(0,-1)],
    'F':[(1,0),(0,1)],
    'J':[(-1,0),(0,-1)]
    }
n,m=map(int,input().split())
grid=[input() for _ in range(n)]
parent=[i for i in range(0,n*m)]

def find(p1):
    if parent[p1]!=p1:
        parent[p1]=find(parent[p1])
    return parent[p1]

def union(n1,n2):
    p1,p2=find(n1),find(n2)
    parent[p1]=parent[p2]
    return

for i in range(n):
    for j in range(m):
        if grid[i][j]!='0':
            for x,y in directions:
                nx=x+i
                ny=y+j
                if 0<=nx<n and 0<=ny<m and grid[nx][ny]!='0' and (x,y) in dL[grid[i][j]] and (-x,-y) in dL[grid[nx][ny]]:
                    union(i*m+j,nx*m+ny)
counter=dict()
for i in range(n):
    for j in range(m):
        if grid[i][j] != '0':
            p=find(i*m+j)
            counter[p]=counter.get(p,0)+1
print(max(counter.values()))

 
#38290: Re: python 紀錄 並查集


BensonDC (python戰士)

學校 : 不指定學校
編號 : 240921
來源 : [163.32.78.214]
最後登入時間 :
2024-11-06 14:27:58
m372. 3. 搬家 -- 2023年10月APCS | From: [1.175.211.7] | 發表日期 : 2023-11-10 10:40

最後紀錄最大連通塊的部分也可以使用Counter計數

 
#39232: Re: python 紀錄 並查集


BensonDC (python戰士)

學校 : 不指定學校
編號 : 240921
來源 : [163.32.78.214]
最後登入時間 :
2024-11-06 14:27:58
m372. 3. 搬家 -- 2023年10月APCS | From: [1.175.210.14] | 發表日期 : 2024-01-25 00:05

directions=[(-1,0),(0,-1)] # 上左
dL={
    'X':[(1,0),(-1,0),(0,1),(0,-1)],# 下上右左
    'I':[(1,0),(-1,0)],
    'H':[(0,1),(0,-1)],
    'L':[(-1,0),(0,1)],
    '7':[(1,0),(0,-1)],
    'F':[(1,0),(0,1)],
    'J':[(-1,0),(0,-1)]
    }
n,m=map(int,input().split())
grid=[input() for _ in range(n)]
parent=list(range(n*m))
res=[1]*(n*m)

def find(p1):
    if parent[p1]!=p1:
        parent[p1]=find(parent[p1])
    return parent[p1]

def union(n1,n2):
    p1,p2=find(n1),find(n2)
    if p1!=p2:
        res[p1]+=res[p2]
        parent[p2]=p1

for i in range(n):
    for j in range(m):
        if grid[i][j]!='0':
            for x,y in directions:
                nx=x+i
                ny=y+j
                if 0<=nx<n and 0<=ny<m and grid[nx][ny]!='0' and (x,y) in dL[grid[i][j]] and (-x,-y) in dL[grid[nx][ny]]:
                    union(i*m+j,nx*m+ny)

print(max(res))

 
ZeroJudge Forum