#39016: Python解體


xx48833@gmail.com (wenyan)

學校 : 國立臺南高級海事水產職業學校
編號 : 218145
來源 : [101.8.23.110]
最後登入時間 :
2024-03-28 16:07:46
m933. 3. 邏輯電路 -- 2024年1月APCS | From: [111.255.97.201] | 發表日期 : 2024-01-08 04:32

首先要對輸入資料進行處理

p,q,r,m = map(int,input().split())
ip = [int(x) for x in input().split()]   #記錄各輸入點的值
gc = [int(x) for x in input().split()]  #記錄各邏輯閘的種類
g  = [[-1,-1,0] for i in range(q)] #[a輸入端 b輸入端 Logic gates] -1=無
gv = [-1 for i in range(q)] #紀錄個邏輯閘輸出值
out = []    #紀錄輸出點 並由小到大排序
to =[[] for i in range(m+1)]    #記錄各點之間的關係
 
邊輸入邊處理邏輯閘的數據
for i in range(m):
    a,b = map(int,input().split())
    if b>p+q:
        out.append([a,b])
    elif b>p and b<=p+q:
        temp =b-(p+1)
        g[temp][2] = gc[temp]
        if g[temp][0]==-1:
            g[temp][0] = a
        else:
            g[temp][1] = a
    to[b].append(a)
out.sort(key=lambda x:x[1])
 
這邊主要由輸出端往輸入端走訪 (如果從輸入端往輸出端走訪記錄延遲,會有邏輯閘空接的狀況)
 
(請自行設計迴圈搭配find)
#由output -> gate -> input 走訪記錄 最大延遲
ans = 0 #設定一個delay最大值的紀錄
def find(now,dp):
    global ans
    dp+=1
    for i in to[now]:
        if i>p:
            find(i,dp)
    ans = max(ans,dp)
    return
 
#取得個邏輯閘輸出值
這邊可以設計自訂函數傳入(接點a ,接點b,邏輯閘種類)
 
提示:判斷接點為 前p個輸入點 或是 邏輯閘的輸出
若是邏輯閘的輸出端點 可用gv[index] 去查找該點的值為何
若尚未計算 則是將該接點編號-p 透過g[index]查找該邏輯閘
並將資料傳入函數內計算以此類推。 
 
#最後整理輸出值
 
#39020: Re: Python解體


s11104220@school.saihs.edu.tw (施同學)

學校 : 臺北市立松山高級工農職業學校
編號 : 221254
來源 : [61.223.232.64]
最後登入時間 :
2024-05-13 16:04:44
m933. 3. 邏輯電路 -- 2024年1月APCS | From: [223.137.214.19] | 發表日期 : 2024-01-08 12:15

首先要對輸入資料進行處理

p,q,r,m = map(int,input().split())
ip = [int(x) for x in input().split()]   #記錄各輸入點的值
gc = [int(x) for x in input().split()]  #記錄各邏輯閘的種類
g  = [[-1,-1,0] for i in range(q)] #[a輸入端 b輸入端 Logic gates] -1=無
gv = [-1 for i in range(q)] #紀錄個邏輯閘輸出值
out = []    #紀錄輸出點 並由小到大排序
to =[[] for i in range(m+1)]    #記錄各點之間的關係
 
邊輸入邊處理邏輯閘的數據
for i in range(m):
    a,b = map(int,input().split())
    if b>p+q:
        out.append([a,b])
    elif b>p and b<=p+q:
        temp =b-(p+1)
        g[temp][2] = gc[temp]
        if g[temp][0]==-1:
            g[temp][0] = a
        else:
            g[temp][1] = a
    to[b].append(a)
out.sort(key=lambda x:x[1])
 
這邊主要由輸出端往輸入端走訪 (如果從輸入端往輸出端走訪記錄延遲,會有邏輯閘空接的狀況)
 
(請自行設計迴圈搭配find)
#由output -> gate -> input 走訪記錄 最大延遲
ans = 0 #設定一個delay最大值的紀錄
def find(now,dp):
    global ans
    dp+=1
    for i in to[now]:
        if i>p:
            find(i,dp)
    ans = max(ans,dp)
    return
 
#取得個邏輯閘輸出值
這邊可以設計自訂函數傳入(接點a ,接點b,邏輯閘種類)
 
提示:判斷接點為 前p個輸入點 或是 邏輯閘的輸出
若是邏輯閘的輸出端點 可用gv[index] 去查找該點的值為何
若尚未計算 則是將該接點編號-p 透過g[index]查找該邏輯閘
並將資料傳入函數內計算以此類推。 
 
#最後整理輸出值

我是輸入往輸出走

算延遲是輸出往輸入

 
#39030: Re: Python解體


s11104220@school.saihs.edu.tw (施同學)

學校 : 臺北市立松山高級工農職業學校
編號 : 221254
來源 : [61.223.232.64]
最後登入時間 :
2024-05-13 16:04:44
m933. 3. 邏輯電路 -- 2024年1月APCS | From: [118.165.10.54] | 發表日期 : 2024-01-08 17:12

首先要對輸入資料進行處理

p,q,r,m = map(int,input().split())
ip = [int(x) for x in input().split()]   #記錄各輸入點的值
gc = [int(x) for x in input().split()]  #記錄各邏輯閘的種類
g  = [[-1,-1,0] for i in range(q)] #[a輸入端 b輸入端 Logic gates] -1=無
gv = [-1 for i in range(q)] #紀錄個邏輯閘輸出值
out = []    #紀錄輸出點 並由小到大排序
to =[[] for i in range(m+1)]    #記錄各點之間的關係
 
邊輸入邊處理邏輯閘的數據
for i in range(m):
    a,b = map(int,input().split())
    if b>p+q:
        out.append([a,b])
    elif b>p and b<=p+q:
        temp =b-(p+1)
        g[temp][2] = gc[temp]
        if g[temp][0]==-1:
            g[temp][0] = a
        else:
            g[temp][1] = a
    to[b].append(a)
out.sort(key=lambda x:x[1])
 
這邊主要由輸出端往輸入端走訪 (如果從輸入端往輸出端走訪記錄延遲,會有邏輯閘空接的狀況)
 
(請自行設計迴圈搭配find)
#由output -> gate -> input 走訪記錄 最大延遲
ans = 0 #設定一個delay最大值的紀錄
def find(now,dp):
    global ans
    dp+=1
    for i in to[now]:
        if i>p:
            find(i,dp)
    ans = max(ans,dp)
    return
 
#取得個邏輯閘輸出值
這邊可以設計自訂函數傳入(接點a ,接點b,邏輯閘種類)
 
提示:判斷接點為 前p個輸入點 或是 邏輯閘的輸出
若是邏輯閘的輸出端點 可用gv[index] 去查找該點的值為何
若尚未計算 則是將該接點編號-p 透過g[index]查找該邏輯閘
並將資料傳入函數內計算以此類推。 
 
#最後整理輸出值

我是輸入往輸出走

算延遲是輸出往輸入

我的程式碼(算延遲有改過 併入算邏輯的迴圈)

def main():
    from sys import stdin
    p,q,r,m=map(int,stdin.readline().split())
    state=[0 for _ in range(p+q+r+1)]#0 1狀態
    lef=state.copy()#剩餘輸入數量
    md=state.copy()#最大距離
    state[1:p+1]=map(int,stdin.readline().split())#獲取輸入
    typ=tuple(map(int,stdin.readline().split()))#種類0 buffer 1 and 2 or 3 XOR 4 NOT
    key=[[] for _ in range(p+q+r+1)]#輸入往輸出的編號
    con=[[] for _ in range(p+q+r+1)]#輸出往輸入的編號
    for _ in range(m):
        a,b=map(int,stdin.readline().split())
        lef[b]+=1#剩餘輸入數量+1
        key[a].append(b)#連接
        if p+q+1>b>p or con[b]==[]:con[b].append(a)#連接 前面判斷式可不寫 用來加速用
    t=[(i,0) for i in range(1,p+1)]
    while t:
        idx,dis=t.pop()
        for kid in key[idx]:#輸入端連接到的
            lef[kid]-=1
            if dis>md[kid]:md[kid]=dis#最大距離
            if lef[kid]==0:#如果閘的輸入01狀態都知道了
                t.append((kid,md[kid]+1))#新增到stack
                if p+q>=kid>p:tk=typ[kid-p-1]#如果是邏輯閘 則對應到typ
                else:tk=0#否則都是buffer或無功能
                if tk==0:
                    state[kid]=state[con[kid][0]]
                elif tk==1:
                    state[kid]=0
                    for j in con[kid]:
                        if state[j]==0:break
                    else:state[kid]=1
                elif tk==2:
                    state[kid]=1
                    for j in con[kid]:
                        if state[j]:break
                    else:state[kid]=0
                elif tk==3:
                    f=0
                    for j in con[kid]:
                        if state[j]:f+=1
                    state[kid]=f%2
                elif tk==4:
                    state[kid]=0 if state[con[kid][0]] else 1
    print(max(md[p+q+1:]))
    print(*state[p+q+1:])
if __name__=="__main__":main()
 
#39031: Re: Python解體


s11104220@school.saihs.edu.tw (施同學)

學校 : 臺北市立松山高級工農職業學校
編號 : 221254
來源 : [61.223.232.64]
最後登入時間 :
2024-05-13 16:04:44
m933. 3. 邏輯電路 -- 2024年1月APCS | From: [118.165.10.54] | 發表日期 : 2024-01-08 17:14

 

我的程式碼(算延遲有改過 併入算邏輯的迴圈)

def main():
    from sys import stdin
    p,q,r,m=map(int,stdin.readline().split())
    state=[0 for _ in range(p+q+r+1)]#0 1狀態
    lef=state.copy()#剩餘輸入數量
    md=state.copy()#最大距離
    state[1:p+1]=map(int,stdin.readline().split())#獲取輸入
    typ=tuple(map(int,stdin.readline().split()))#種類0 buffer 1 and 2 or 3 XOR 4 NOT
    key=[[] for _ in range(p+q+r+1)]#輸入往輸出的編號
    con=[[] for _ in range(p+q+r+1)]#輸出往輸入的編號
    for _ in range(m):
        a,b=map(int,stdin.readline().split())
        lef[b]+=1#剩餘輸入數量+1
        key[a].append(b)#連接
        if p+q+1>b>p or con[b]==[]:con[b].append(a)#連接 前面判斷式可不寫 用來加速用
    t=[(i,0) for i in range(1,p+1)]
    while t:
        idx,dis=t.pop()
        for kid in key[idx]:#輸入端連接到的
            lef[kid]-=1
            if dis>md[kid]:md[kid]=dis#最大距離
            if lef[kid]==0:#如果閘的輸入01狀態都知道了
                t.append((kid,md[kid]+1))#新增到stack
                if p+q>=kid>p:tk=typ[kid-p-1]#如果是邏輯閘 則對應到typ
                else:tk=0#否則都是buffer或無功能
                if tk==0:
                    state[kid]=state[con[kid][0]]
                elif tk==1:
                    state[kid]=0
                    for j in con[kid]:
                        if state[j]==0:break
                    else:state[kid]=1
                elif tk==2:
                    state[kid]=1
                    for j in con[kid]:
                        if state[j]:break
                    else:state[kid]=0
                elif tk==3:
                    f=0
                    for j in con[kid]:
                        if state[j]:f+=1
                    state[kid]=f%2
                elif tk==4:
                    state[kid]=0 if state[con[kid][0]] else 1
    print(max(md[p+q+1:]))
    print(*state[p+q+1:])
if __name__=="__main__":main()

我的類似 開啟寶盒 的做法

 
#39033: Re: Python解體


s11104220@school.saihs.edu.tw (施同學)

學校 : 臺北市立松山高級工農職業學校
編號 : 221254
來源 : [61.223.232.64]
最後登入時間 :
2024-05-13 16:04:44
m933. 3. 邏輯電路 -- 2024年1月APCS | From: [118.165.10.54] | 發表日期 : 2024-01-08 18:23

 

我的程式碼(算延遲有改過 併入算邏輯的迴圈)

def main():
    from sys import stdin
    p,q,r,m=map(int,stdin.readline().split())
    state=[0 for _ in range(p+q+r+1)]#0 1狀態
    lef=state.copy()#剩餘輸入數量
    md=state.copy()#最大距離
    state[1:p+1]=map(int,stdin.readline().split())#獲取輸入
    typ=tuple(map(int,stdin.readline().split()))#種類0 buffer 1 and 2 or 3 XOR 4 NOT
    key=[[] for _ in range(p+q+r+1)]#輸入往輸出的編號
    con=[[] for _ in range(p+q+r+1)]#輸出往輸入的編號
    for _ in range(m):
        a,b=map(int,stdin.readline().split())
        lef[b]+=1#剩餘輸入數量+1
        key[a].append(b)#連接
        if p+q+1>b>p or con[b]==[]:con[b].append(a)#連接 前面判斷式可不寫 用來加速用
    t=[(i,0) for i in range(1,p+1)]
    while t:
        idx,dis=t.pop()
        for kid in key[idx]:#輸入端連接到的
            lef[kid]-=1
            if dis>md[kid]:md[kid]=dis#最大距離
            if lef[kid]==0:#如果閘的輸入01狀態都知道了
                t.append((kid,md[kid]+1))#新增到stack
                if p+q>=kid>p:tk=typ[kid-p-1]#如果是邏輯閘 則對應到typ
                else:tk=0#否則都是buffer或無功能
                if tk==0:
                    state[kid]=state[con[kid][0]]
                elif tk==1:
                    state[kid]=0
                    for j in con[kid]:
                        if state[j]==0:break
                    else:state[kid]=1
                elif tk==2:
                    state[kid]=1
                    for j in con[kid]:
                        if state[j]:break
                    else:state[kid]=0
                elif tk==3:
                    f=0
                    for j in con[kid]:
                        if state[j]:f+=1
                    state[kid]=f%2
                elif tk==4:
                    state[kid]=0 if state[con[kid][0]] else 1
    print(max(md[p+q+1:]))
    print(*state[p+q+1:])
if __name__=="__main__":main()

我的類似 開啟寶盒 的做法

我剛剛把con刪掉了 空間會少一點

def main():
    from sys import stdin
    F=stdin.readline
    p,q,r,m=map(int,F().split());pqr=p+q+r;pq=p+q
    st=[0 for _ in range(pqr)]
    lef=st.copy()
    md=st.copy()
    st[:p]=map(int,F().split())
    lst=[[0,0] for _ in range(pqr)]
    typ=tuple(map(int,F().split()))
    key=[[] for _ in range(pqr)]
    for _ in range(m):
        a,b=map(int,F().split())
        lef[b-1]+=1
        key[a-1].append(b-1)
    t=[(i,0) for i in range(p)]
    while t:
        idx,dis=t.pop()
        for kid in key[idx]:
            lef[kid]-=1
            if dis>md[kid]:md[kid]=dis
            lsk=lst[kid]
            lsk[st[idx]]+=1
            if lef[kid]==0:
                t.append((kid,md[kid]+1))
                if pq>kid>=p:tk=typ[kid-p]
                else:tk=0
                if tk%2==0:
                    if tk!=4:st[kid]=1 if lsk[1] else 0
                    else:st[kid]=0 if lsk[1] else 1
                elif tk==1:
                    st[kid]=0 if lsk[0] else 1
                elif tk==3:
                    st[kid]=lsk[1]%2
    print(max(md[pq:]))
    print(*st[pq:])
if __name__=="__main__":main()
 
#39040: Re: Python解體


denny20040902@gmail.com (Denny Yang)

學校 : 國立中央大學附屬中壢高級中學
編號 : 174787
來源 : [210.208.117.19]
最後登入時間 :
2024-01-10 16:02:34
m933. 3. 邏輯電路 -- 2024年1月APCS | From: [36.231.221.225] | 發表日期 : 2024-01-09 02:50

首先要對輸入資料進行處理

p,q,r,m = map(int,input().split())
ip = [int(x) for x in input().split()]   #記錄各輸入點的值
gc = [int(x) for x in input().split()]  #記錄各邏輯閘的種類
g  = [[-1,-1,0] for i in range(q)] #[a輸入端 b輸入端 Logic gates] -1=無
gv = [-1 for i in range(q)] #紀錄個邏輯閘輸出值
out = []    #紀錄輸出點 並由小到大排序
to =[[] for i in range(m+1)]    #記錄各點之間的關係
 
邊輸入邊處理邏輯閘的數據
for i in range(m):
    a,b = map(int,input().split())
    if b>p+q:
        out.append([a,b])
    elif b>p and b<=p+q:
        temp =b-(p+1)
        g[temp][2] = gc[temp]
        if g[temp][0]==-1:
            g[temp][0] = a
        else:
            g[temp][1] = a
    to[b].append(a)
out.sort(key=lambda x:x[1])
 
這邊主要由輸出端往輸入端走訪 (如果從輸入端往輸出端走訪記錄延遲,會有邏輯閘空接的狀況)
 
(請自行設計迴圈搭配find)
#由output -> gate -> input 走訪記錄 最大延遲
ans = 0 #設定一個delay最大值的紀錄
def find(now,dp):
    global ans
    dp+=1
    for i in to[now]:
        if i>p:
            find(i,dp)
    ans = max(ans,dp)
    return
 
#取得個邏輯閘輸出值
這邊可以設計自訂函數傳入(接點a ,接點b,邏輯閘種類)
 
提示:判斷接點為 前p個輸入點 或是 邏輯閘的輸出
若是邏輯閘的輸出端點 可用gv[index] 去查找該點的值為何
若尚未計算 則是將該接點編號-p 透過g[index]查找該邏輯閘
並將資料傳入函數內計算以此類推。 
 
#最後整理輸出值
 
我用python寫 也是從輸入點用DFS走訪到輸出點 並記錄最大延遲還有記錄各點的值
但只拿到10% 後面都TLE 
請問怎麼各位大神怎麼優化的🙏

 


    

 



 
#39041: Re: Python解體


denny20040902@gmail.com (Denny Yang)

學校 : 國立中央大學附屬中壢高級中學
編號 : 174787
來源 : [210.208.117.19]
最後登入時間 :
2024-01-10 16:02:34
m933. 3. 邏輯電路 -- 2024年1月APCS | From: [36.231.221.225] | 發表日期 : 2024-01-09 02:51

首先要對輸入資料進行處理

p,q,r,m = map(int,input().split())
ip = [int(x) for x in input().split()]   #記錄各輸入點的值
gc = [int(x) for x in input().split()]  #記錄各邏輯閘的種類
g  = [[-1,-1,0] for i in range(q)] #[a輸入端 b輸入端 Logic gates] -1=無
gv = [-1 for i in range(q)] #紀錄個邏輯閘輸出值
out = []    #紀錄輸出點 並由小到大排序
to =[[] for i in range(m+1)]    #記錄各點之間的關係
 
邊輸入邊處理邏輯閘的數據
for i in range(m):
    a,b = map(int,input().split())
    if b>p+q:
        out.append([a,b])
    elif b>p and b<=p+q:
        temp =b-(p+1)
        g[temp][2] = gc[temp]
        if g[temp][0]==-1:
            g[temp][0] = a
        else:
            g[temp][1] = a
    to[b].append(a)
out.sort(key=lambda x:x[1])
 
這邊主要由輸出端往輸入端走訪 (如果從輸入端往輸出端走訪記錄延遲,會有邏輯閘空接的狀況)
 
(請自行設計迴圈搭配find)
#由output -> gate -> input 走訪記錄 最大延遲
ans = 0 #設定一個delay最大值的紀錄
def find(now,dp):
    global ans
    dp+=1
    for i in to[now]:
        if i>p:
            find(i,dp)
    ans = max(ans,dp)
    return
 
#取得個邏輯閘輸出值
這邊可以設計自訂函數傳入(接點a ,接點b,邏輯閘種類)
 
提示:判斷接點為 前p個輸入點 或是 邏輯閘的輸出
若是邏輯閘的輸出端點 可用gv[index] 去查找該點的值為何
若尚未計算 則是將該接點編號-p 透過g[index]查找該邏輯閘
並將資料傳入函數內計算以此類推。 
 
#最後整理輸出值
 

 


    

 



我用python寫 也是從輸入點用DFS走訪到輸出點 並記錄最大延遲還有記錄各點的值
但只拿到10% 後面都TLE 
請問怎麼各位大神怎麼優化的🙏

 
#39044: Re: Python解體


s11104220@school.saihs.edu.tw (施同學)

學校 : 臺北市立松山高級工農職業學校
編號 : 221254
來源 : [61.223.232.64]
最後登入時間 :
2024-05-13 16:04:44
m933. 3. 邏輯電路 -- 2024年1月APCS | From: [114.136.169.94] | 發表日期 : 2024-01-09 12:16

首先要對輸入資料進行處理

p,q,r,m = map(int,input().split())
ip = [int(x) for x in input().split()]   #記錄各輸入點的值
gc = [int(x) for x in input().split()]  #記錄各邏輯閘的種類
g  = [[-1,-1,0] for i in range(q)] #[a輸入端 b輸入端 Logic gates] -1=無
gv = [-1 for i in range(q)] #紀錄個邏輯閘輸出值
out = []    #紀錄輸出點 並由小到大排序
to =[[] for i in range(m+1)]    #記錄各點之間的關係
 
邊輸入邊處理邏輯閘的數據
for i in range(m):
    a,b = map(int,input().split())
    if b>p+q:
        out.append([a,b])
    elif b>p and b<=p+q:
        temp =b-(p+1)
        g[temp][2] = gc[temp]
        if g[temp][0]==-1:
            g[temp][0] = a
        else:
            g[temp][1] = a
    to[b].append(a)
out.sort(key=lambda x:x[1])
 
這邊主要由輸出端往輸入端走訪 (如果從輸入端往輸出端走訪記錄延遲,會有邏輯閘空接的狀況)
 
(請自行設計迴圈搭配find)
#由output -> gate -> input 走訪記錄 最大延遲
ans = 0 #設定一個delay最大值的紀錄
def find(now,dp):
    global ans
    dp+=1
    for i in to[now]:
        if i>p:
            find(i,dp)
    ans = max(ans,dp)
    return
 
#取得個邏輯閘輸出值
這邊可以設計自訂函數傳入(接點a ,接點b,邏輯閘種類)
 
提示:判斷接點為 前p個輸入點 或是 邏輯閘的輸出
若是邏輯閘的輸出端點 可用gv[index] 去查找該點的值為何
若尚未計算 則是將該接點編號-p 透過g[index]查找該邏輯閘
並將資料傳入函數內計算以此類推。 
 
#最後整理輸出值
 

 


    

 



我用python寫 也是從輸入點用DFS走訪到輸出點 並記錄最大延遲還有記錄各點的值
但只拿到10% 後面都TLE 
請問怎麼各位大神怎麼優化的🙏

程式碼?

你可能時間複雜度太高

 
#39050: Re: Python解體


denny20040902@gmail.com (Denny Yang)

學校 : 國立中央大學附屬中壢高級中學
編號 : 174787
來源 : [210.208.117.19]
最後登入時間 :
2024-01-10 16:02:34
m933. 3. 邏輯電路 -- 2024年1月APCS | From: [210.208.117.43] | 發表日期 : 2024-01-09 23:59

首先要對輸入資料進行處理

p,q,r,m = map(int,input().split())
ip = [int(x) for x in input().split()]   #記錄各輸入點的值
gc = [int(x) for x in input().split()]  #記錄各邏輯閘的種類
g  = [[-1,-1,0] for i in range(q)] #[a輸入端 b輸入端 Logic gates] -1=無
gv = [-1 for i in range(q)] #紀錄個邏輯閘輸出值
out = []    #紀錄輸出點 並由小到大排序
to =[[] for i in range(m+1)]    #記錄各點之間的關係
 
邊輸入邊處理邏輯閘的數據
for i in range(m):
    a,b = map(int,input().split())
    if b>p+q:
        out.append([a,b])
    elif b>p and b<=p+q:
        temp =b-(p+1)
        g[temp][2] = gc[temp]
        if g[temp][0]==-1:
            g[temp][0] = a
        else:
            g[temp][1] = a
    to[b].append(a)
out.sort(key=lambda x:x[1])
 
這邊主要由輸出端往輸入端走訪 (如果從輸入端往輸出端走訪記錄延遲,會有邏輯閘空接的狀況)
 
(請自行設計迴圈搭配find)
#由output -> gate -> input 走訪記錄 最大延遲
ans = 0 #設定一個delay最大值的紀錄
def find(now,dp):
    global ans
    dp+=1
    for i in to[now]:
        if i>p:
            find(i,dp)
    ans = max(ans,dp)
    return
 
#取得個邏輯閘輸出值
這邊可以設計自訂函數傳入(接點a ,接點b,邏輯閘種類)
 
提示:判斷接點為 前p個輸入點 或是 邏輯閘的輸出
若是邏輯閘的輸出端點 可用gv[index] 去查找該點的值為何
若尚未計算 則是將該接點編號-p 透過g[index]查找該邏輯閘
並將資料傳入函數內計算以此類推。 
 
#最後整理輸出值
 

 


    

 



我用python寫 也是從輸入點用DFS走訪到輸出點 並記錄最大延遲還有記錄各點的值
但只拿到10% 後面都TLE 
請問怎麼各位大神怎麼優化的🙏

程式碼?

你可能時間複雜度太高

程式碼在這 再請各位大神給意見🙏
然後我上面好像打錯了 我是從輸出點走訪到輸入點 跟原po一樣

from sys import stdin
from collections import defaultdict

p,q,r,m=map(int,stdin.readline().strip().split())
ip=list(map(int,stdin.readline().strip().split()))  #用list記錄各輸入點的值(索引值=編號-1)
gate=list(map(int,stdin.readline().strip().split()))  #用list紀錄邏輯閘的種類(索引值=編號-1)
graph=defaultdict(list)  #建立字典用於紀錄點與點的關係
for _ in range(m):
    a,b=map(int,stdin.readline().strip().split())
    graph[b].append(a)  #紀錄終端端口連接起始端口 (為了從輸出點走訪到輸入點)

delay=[0]*(p+q)  #走到各點的最大延遲 (索引值=編號-1)
value=[0]*(p+q+r)  #各點的值 (索引值=編號-1)

def DFS(x):  #DFS從輸出點遍歷到輸入點,並一邊紀錄各點的值和紀錄走到各點的最大延遲
    if x <= p:  #若x為輸入點
        value[x-1]=ip[x-1]
        return
    elif p+1 <= x <= p+q:  #若x為邏輯閘
        if 1 <= gate[x-p-1] <=3:  #若x為AND、OR、XOR,代表x一定連接兩端。x的值由兩端和本身邏輯閘種類決定,走到x的最大延遲為兩端點中延遲較大者+1
            DFS(graph[x][0])
            DFS(graph[x][1])
            value[x-1] = logic(value[graph[x][0]-1],value[graph[x][1]-1],gate[x-p-1])   
            delay[x-1]=max(delay[graph[x][0]-1],delay[graph[x][1]-1])+1
        else:                                  #否則x為NOT,代表x只連接一端
            DFS(graph[x][0])
            value[x-1] = int(not value[graph[x][0]-1])
            delay[x-1]=delay[graph[x][0]-1]+1
    else:          #否則x為輸出點
        DFS(graph[x][0])
        value[x-1]=value[graph[x][0]-1]

def logic(g1,g2,g3): #計算AND、OR、XOR三種邏輯閘接收兩個輸入點後輸出的值
    if g3==1:
        return g1 and g2
    elif g3==2:
        return g1 or g2
    else:
        return g1^g2

for out in range(p+q+1,p+q+r+1): #從每個輸出點開始走訪
    DFS(out)
print(max(delay))
print(*value[p+q:p+q+r:])



 
#39051: Re: Python解體


s11104220@school.saihs.edu.tw (施同學)

學校 : 臺北市立松山高級工農職業學校
編號 : 221254
來源 : [61.223.232.64]
最後登入時間 :
2024-05-13 16:04:44
m933. 3. 邏輯電路 -- 2024年1月APCS | From: [114.136.146.249] | 發表日期 : 2024-01-10 08:00

 

有沒有可能 有一條線 連接到 多個輸出閘

這條線往輸入的地方又有大量的路徑?

你可以多一個判斷

DFS如果value已經改過了 直接return

 
#39052: Re: Python解體


s11104220@school.saihs.edu.tw (施同學)

學校 : 臺北市立松山高級工農職業學校
編號 : 221254
來源 : [61.223.232.64]
最後登入時間 :
2024-05-13 16:04:44
m933. 3. 邏輯電路 -- 2024年1月APCS | From: [114.136.146.249] | 發表日期 : 2024-01-10 08:02

 

有沒有可能 有一條線 連接到 多個輸出閘

這條線往輸入的地方又有大量的路徑?

你可以多一個判斷

DFS如果value已經改過了 直接return


可以把value預設改為-1

0 1代表已經確定狀態

我晚點再測試看看

 
#39054: Re: Python解體


s11104220@school.saihs.edu.tw (施同學)

學校 : 臺北市立松山高級工農職業學校
編號 : 221254
來源 : [61.223.232.64]
最後登入時間 :
2024-05-13 16:04:44
m933. 3. 邏輯電路 -- 2024年1月APCS | From: [114.136.146.249] | 發表日期 : 2024-01-10 08:45

 

有沒有可能 有一條線 連接到 多個輸出閘

這條線往輸入的地方又有大量的路徑?

你可以多一個判斷

DFS如果value已經改過了 直接return


可以把value預設改為-1

0 1代表已經確定狀態

我晚點再測試看看


Worst case 5×10^3 output×(5×10^4 gate +10^3 input)

 
#39060: Re: Python解體


s11104220@school.saihs.edu.tw (施同學)

學校 : 臺北市立松山高級工農職業學校
編號 : 221254
來源 : [61.223.232.64]
最後登入時間 :
2024-05-13 16:04:44
m933. 3. 邏輯電路 -- 2024年1月APCS | From: [114.136.146.249] | 發表日期 : 2024-01-10 13:29

 

有沒有可能 有一條線 連接到 多個輸出閘

這條線往輸入的地方又有大量的路徑?

你可以多一個判斷

DFS如果value已經改過了 直接return


可以把value預設改為-1

0 1代表已經確定狀態

我晚點再測試看看


Worst case 5×10^3 output×(5×10^4 gate +10^3 input)



你的程式碼只要改一行 + 新增一行就過了

 
#39063: Re: Python解體


denny20040902@gmail.com (Denny Yang)

學校 : 國立中央大學附屬中壢高級中學
編號 : 174787
來源 : [210.208.117.19]
最後登入時間 :
2024-01-10 16:02:34
m933. 3. 邏輯電路 -- 2024年1月APCS | From: [210.208.117.19] | 發表日期 : 2024-01-10 16:08

 

有沒有可能 有一條線 連接到 多個輸出閘

這條線往輸入的地方又有大量的路徑?

你可以多一個判斷

DFS如果value已經改過了 直接return


可以把value預設改為-1

0 1代表已經確定狀態

我晚點再測試看看


Worst case 5×10^3 output×(5×10^4 gate +10^3 input)



你的程式碼只要改一行 + 新增一行就過了

幹真的AC了 感謝哥 你是我的神🙏
不知道原來差這個判斷差那麼多

 
ZeroJudge Forum