Câu hỏi:
26/06/2024 67Viết lại các hàm thiết lập đồ thị BuildGraph(fname) với tệp dữ liệu đầu vào là danh sách các cạnh của đồ thị. Đầu ra của hàm là dãy các giá trị V, E, A, Adj. Viết hàm cho cả hai trường hợp đồ thị vô hướng và đồ thị có hướng.
Sách mới 2k7: Tổng ôn Toán, Lí, Hóa, Văn, Sử, Địa…. kỳ thi tốt nghiệp THPT Quốc gia 2025, đánh giá năng lực (chỉ từ 110k).
Quảng cáo
Trả lời:
Dưới đây là mã Python cho các hàm thiết lập đồ thị BuildGraph dựa trên danh sách các cạnh của đồ thị:
def BuildGraph(fname):
V = set()
E = []
with open(fname, 'r') as file:
for line in file:
edge = tuple(map(int, line.strip().split())) # Chuyển đổi dòng thành cạnh (u, v)
V.add(edge[0]) # Thêm đỉnh u vào tập đỉnh
V.add(edge[1]) # Thêm đỉnh v vào tập đỉnh
E.append(edge) # Thêm cạnh vào danh sách các cạnh
V = sorted(V) # Sắp xếp tập đỉnh
n = len(V)
# Khởi tạo ma trận kề và danh sách kề
A = [[0] * n for _ in range(n)] # Ma trận kề
Adj = [[] for _ in range(n)] # Danh sách kề
# Điền thông tin vào ma trận kề và danh sách kề
for edge in E:
u, v = edge
A[u][v] = 1 # Đánh dấu cạnh (u, v) trong ma trận kề
Adj[u].append(v) # Thêm v vào danh sách kề của u
return V, E, A, Adj
# Sử dụng hàm BuildGraph cho đồ thị vô hướng
V, E, A, Adj = BuildGraph('graph_edges.txt')
print("Đồ thị vô hướng:")
print("Tập đỉnh:", V)
print("Tập cạnh:", E)
print("Ma trận kề:")
for row in A:
print(row)
print("Danh sách kề:")
for i, neighbors in enumerate(Adj):
print(f"{i}: {neighbors}")
# Sử dụng hàm BuildGraph cho đồ thị có hướng
V, E, A, Adj = BuildGraph('digraph_edges.txt')
print("\nĐồ thị có hướng:")
print("Tập đỉnh:", V)
print("Tập cạnh:", E)
print("Ma trận kề:")
for row in A:
print(row)
print("Danh sách kề:")
for i, neighbors in enumerate(Adj):
print(f"{i}: {neighbors}")
- Trong mã trên:
- Hàm BuildGraph đọc tệp dữ liệu đầu vào và xây dựng các biểu diễn của đồ thị: tập đỉnh VVV, tập cạnh EEE, ma trận kề AAA, và danh sách kề Adj\text{Adj}Adj.
- Hàm đọc dữ liệu từ tệp dựa trên định dạng: mỗi dòng trong tệp biểu diễn một cạnh của đồ thị.
- Các biểu diễn của đồ thị được trả về cho cả hai trường hợp đồ thị vô hướng và có hướng.
CÂU HỎI HOT CÙNG CHỦ ĐỀ
Câu 1:
Cây nhị phân có thể được coi là đồ thị vô hướng, các nút của cây sẽ tương ứng là đỉnh, còn quan hệ cha-con là cạnh nối của đồ thị. Với cây nhị phân hoàn chỉnh, các đỉnh được đánh số theo chỉ số của mảng biểu diễn tương ứng của cây. Hãy tính ma trận kề của đồ thị tương ứng cây nhị phân ở hình bên.
Câu 2:
Em hãy trao đổi, thảo luận và trả lời một số câu hỏi sau:
– Nếu đồ thị là vô hướng thì ma trận kề có đặc điểm gì?
– Phân biệt sự giống nhau và khác nhau giữa ma trận kề và danh sách kề?
– Khái niệm bậc của các đỉnh có gì khác nhau trong trường hợp đồ thị là vô hướng, có hướng?
Câu 3:
Trong Nhiệm vụ 2, chúng ta có thể thấy các đỉnh kề không được in ra theo thứ tự tăng dần của chỉ số trong biểu diễn danh sách kề. Em hãy giải thích tại sao. Có thể chỉnh sửa chương trình để in ra các đỉnh kề theo thứ tự chỉ số tăng dần được không?
Câu 4:
Trong Nhiệm vụ 1, hàm In_danh_sach_dinh_ke() lấy thông tin từ ma trận kề A. Có thể sử dụng hàm này với dữ liệu là danh sách kề Adj được không? Nếu có thì viết lại hàm này với dữ liệu đầu vào là danh sách kề Adj.
263 câu Trắc nghiệm tổng hợp ôn thi tốt nghiệp THPT môn Tin học Chủ đề F. Giải quyết vấn đề với sự trợ giúp của máy tính có đáp án
15 câu Trắc nghiệm Tin học 12 KNTT Bài 7: HTML và cấu trúc trang web
Đề thi học kì 1 Tin học 12 Kết nối tri thức có đáp án- Đề 1
15 câu Trắc nghiệm Tin học 12 KNTT Bài 10: Tạo liên kết
15 câu Trắc nghiệm Tin học 12 KNTT Bài 11: Chèn tệp tin đa phương tiện và khung nội tuyến vào trang web
15 câu Trắc nghiệm Tin học 12 KNTT Bài 9: Tạo danh sách, bảng
15 câu Trắc nghiệm Tin học 12 KNTT Bài 8: Định dạng văn bản
15 câu Trắc nghiệm Tin học 12 Cánh diều Bài 1: Làm quen với ngôn ngữ đánh dấu siêu văn bản
về câu hỏi!