Viết hàm trả về danh sách hai chiều chuyển vị. (Tham số là danh sách hai chiều MxN)
Bài tập Python tự luyện

Danh sách bài học
Viết hàm trả về danh sách hai chiều chuyển vị. (Tham số là danh sách hai chiều MxN)
Bài toán cần xử lý
Viết hàm với tham số truyền vào là một danh sách hai chiều kích thước MxN. Trả về danh sách hai chiều chuyển vị (cột thành hàng, hàng thành cột).
Kiến thức cần có
- Hàm input() và hàm print()
- Cấu trúc lặp trong Python
- Cấu trúc rẽ nhánh trong Python
- Biến và kiểu dữ liệu
- Hàm trong Python
- Xử lý ngoại lệ (Exception Handling)
- Các phương thức xử lý List trong Python:
- split()
- len()
- Unpacking arguments
Định dạng đầu vào
Gồm hai dòng:
- Dòng đầu tiên chứa hai giá trị M, N cách nhau bởi khoảng trắng.
- M dòng tiếp theo, mỗi dòng chứa N phần tử, các phần tử cách nhau bởi khoảng trắng
Định dạng đầu ra
- Gồm N dòng, mỗi dòng hiển thị M phần tử của danh sách hai chiều chuyển vị. Các phần tử cách nhau bởi khoảng trắng.
Lưu ý: Nếu M, N nhỏ hơn hoặc bằng 0 thì xuất thông báo: Vui long nhap kich thuoc danh sach la so nguyen duong.
Nếu danh sách hai chiều nhập vào không đúng kích thước MxN thì xuất thông báo: Danh sach hai chieu khong dung kich thuoc!
Nếu input nằm ngoài định dạng đầu vào thì xuất thông báo: Dinh dang dau vao khong hop le!
Ví dụ
- Input 1:
3 4
1 2 3 4
nam sau bay tam
9 muoi 11 12
- Output 1:
1 nam 9
2 sau muoi
3 bay 11
4 tam 12
- Input 2:
1 1
Kteam
- Output 2:
Kteam
- Input 3:
-5 0
- Output 3:
Vui long nhap kich thuoc danh sach la so nguyen duong!
- Input 4:
3 2
1 hai
1 2 ba
- Output 4:
Danh sach hai chieu khong dung kich thuoc da khai bao!
- Input 5:
4 5 Kteam
- Output 5:
Dinh dang dau vao khong hop le!
Gợi ý
- Định nghĩa hàm nhap_danh_sach và in_danh_sach (Tham khảo Bài 90)
- Định nghĩa hàm danh_sach_chuyen_vi với tham số là một danh sách hai chiều:
- Khởi tạo danh sách rỗng để lưu trữ ma trận chuyển vị
- Tính lại số dòng và số cột của danh sách chuyển vị
- Sử dụng vòng lặp for và biến chạy i để duyệt qua tất cả các cột của danh sách.
- Sử dụng List Comprehension lấy phần tử ở cột i của tất cả các hàng
- Thêm danh sách cột thứ i vào danh sách chuyển vị
- Trả danh sách chuyển vị về cho hàm
- Sử dụng cấu trúc Xử lý ngoại lệ để xử lý các trường hợp gây ra lỗi khi ép kiểu dữ liệu
- Đặt chương trình trong khối try.
- Dùng hàm input(), split(), map() và int() để nhập kích thước M, N của danh sách hai chiều và ép kiểu dữ liệu sang số nguyên.
- Sử dụng cấu trúc rẽ nhánh để kiểm tra xem M, N có là số nguyên dương hay không. Xuất thông báo lỗi nếu có.
- Gọi hàm nhap_danh_sach, danh_sach_chuyen_vi, in_danh_sach và truyền vào các tham số cần thiết.
- Lỗi sẽ phát sinh ở lệnh ép kiểu nếu định dạng đầu vào không hợp lệ. Dùng lệnh except để bắt lỗi:
- Dùng hàm print() hiển thị thông báo lỗi ra màn hình.
Code mẫu
def nhap_danh_sach(M, N):
#Khoi tao danh sach rong
danhSach2Chieu = []
for i in range(M):
#Nhap du lieu tung hang tu ban phim va cat thanh list cac phan tu
hang = input().split()
#Kiem tra so phan tu co dung kich thuoc
if len(hang) != N:
print("Danh sach hai chieu khong dung kich thuoc!")
return None
#Them hang vao danh sach 2 chieu
danhSach2Chieu.append(hang)
return danhSach2Chieu
def in_danh_sach(danhSach2Chieu):
#Su dung vong lap for duyet tung hang cua danh sach 2 chieu
for hang in danhSach2Chieu:
#Unpacking arguments
print(*hang)
def danh_sach_chuyen_vi(danhSach2Chieu):
#Khoi tao danh sach rong
dsChuyenVi = []
#So dong cua danh sach moi bang so cot cua danh sach cu va nguoc lai
M = len(danhSach2Chieu[0])
N = len(danhSach2Chieu)
#Su dung vong lap for duyet tung cot cua danh sach 2 chieu
for i in range(M):
#List Comprehension lay phan tu thu i cua tat ca cac hang
cot = [danhSach2Chieu[j][i] for j in range(N)]
#Them vao danh sach chuyen vi moi
dsChuyenVi.append(cot)
return dsChuyenVi
#Khoi lenh co the phat sinh loi
try:
#Nhap kich thuoc danh sach 2 chieu tu ban phim
#M - So dong, N - So cot
M, N = map(int, input().split())
#Kiem tra dieu kien M, N <=0
if M <=0 or N <=0:
print("Vui long nhap kich thuoc danh sach la so nguyen duong!")
else:
#Goi ham nhap danh sach va truyen vao tham so kich thuoc M, N
danhSach2Chieu = nhap_danh_sach(M, N)
if danhSach2Chieu is not None:
#Goi ham va truyen vao tham so la danh sach 2 chieu
dsChuyenVi = danh_sach_chuyen_vi(danhSach2Chieu)
in_danh_sach(dsChuyenVi)
#Khoi lenh duoc thuc thi khi loi xay ra
except:
print("Dinh dang dau vao khong hop le!")
Kết luận
Trong bài này, Kteam đã hướng dẫn bạn cách viết hàm với tham số truyền vào là một danh sách hai chiều kích thước MxN. Trả về danh sách hai chiều chuyển vị (cột thành hàng, hàng thành cột). Thêm bài giải của bạn vào phần bình luận để được Kteam review code và fix lỗi (nếu có) trong livestream của khóa học này.
Ở bài tiếp theo, chúng ta sẽ cũng nhau học cách VIẾT HÀM TRẢ VỀ DANH SÁCH PHẦN TỬ XUẤT HIỆN Ở TẤT CẢ CÁC HÀNG. (THAM SỐ LÀ DANH SÁCH HAI CHIỀU MxN).
Cảm ơn các bạn đã theo dõi bài viết. Hãy để lại bình luận hoặc góp ý của bạn để phát triển bài viết tốt hơn. Đừng quên " Luyện tập - Thử Thách - Không ngại khó!"
Tải xuống
Tài liệu
Nhằm phục vụ mục đích học tập Offline của cộng đồng, Kteam hỗ trợ tính năng lưu trữ nội dung bài học Viết hàm trả về danh sách hai chiều chuyển vị. (Tham số là danh sách hai chiều MxN) dưới dạng file PDF trong link bên dưới.
Ngoài ra, bạn cũng có thể tìm thấy các tài liệu được đóng góp từ cộng đồng ở mục TÀI LIỆU trên thư viện Howkteam.com
Đừng quên like và share để ủng hộ Kteam và tác giả nhé!

Thảo luận
Nếu bạn có bất kỳ khó khăn hay thắc mắc gì về khóa học, đừng ngần ngại đặt câu hỏi trong phần bên dưới hoặc trong mục HỎI & ĐÁP trên thư viện Howkteam.com để nhận được sự hỗ trợ từ cộng đồng.
Nội dung bài viết
Khóa học
Serial dành cho những bạn cần luyện tập phương pháp, tu duy lập trình. Làm quen với các bài toán trong lập trình, ngẫu nhiên từ cơ bản đến nâng cao. Nội dung Serial này được phân tách chi tiết nhất có thể, nhằm giúp các bạn dễ hiểu và thực hành được ngay.
Bạn nên tự làm lại từng bài tập trên video để có kết quả tốt nhất. Cùng Kteam "Luyện tập - Thử thách - không ngại khó"
def creat_dim_lst(row, col):
lst = []
for _ in range(row):
s = input().split()
if len(s) != col:
print("input of range out of matrix size")
return
lst.append(s)
return lst
def prin_dim_lst(s):
result = []
row, col = len(s[0]), len(s)
for i in range(row):
delight_lst = [s[j][i] for j in range(col)]
result.append(delight_lst)
return result
try:
a, b = map(int, input().split())
if a < 1 or b < 1:
print("matrix size error")
else:
result = prin_dim_lst(creat_dim_lst(a,b))
for item in result:
print(*item)
except ValueError:
print("error")
def func(parent_lst):
transpose_lst = [[child_lst[i] for child_lst in parent_lst] for i in range(len(parent_lst[0]))]
[print(*child_lst) for child_lst in transpose_lst]
while True:
try:
m,n = map(int,input("Nhập m, n: ").split())
parent_lst = []
for i in range(m):
parent_lst.append(input(f"Nhập {n} phần tử: ").split())
if m <= 0 or n <= 0:
print("Vui lòng nhập kích thước danh sách là số nguyên dương!")
elif m*n != sum(len(child_lst) for child_lst in parent_lst):
print("Danh sách hai chiều không đúng kích thước!")
else:
func(parent_lst)
break
except:
print("Định dạng đầu vào không hợp lệ!")
m=int(input("Số dòng: "))
n=int(input("Số cột: "))
# CÁCH 1:-----------------------------------------------------------
def func_(m,n):
matrix=[] # Thiết lập matrix
row=[]
for i in range(m):
for j in range(n):
value=str(input(f'Nhập giá trị dòng {i+1}, cột {j+1}: '))
row.append(value)
matrix.append(row) # Thêm cả dòng vào matrix
row=[]
row=[] # Chuyển vị ma trận
matrix_new=[]
for j in range(4):
for i in range(3):
value=matrix[i][j]
row.append(value)
matrix_new.append(row)
row=[]
for row in matrix: # in ma trận
for value in row:
print(value, end="\t") # '/t' để tạo khoảng trắng thay tab
print()
print("MATRIX NEW CÁCH 1")
for row in matrix_new: # in ma trận
for value in row:
print(value, end="\t") # '/t' để tạo khoảng trắng thay tab
print()
func_(m,n)
# CÁCH 2:-----------------------------------------------------------
def func_2(m,n):
matrix=[] # Thiết lập matrix
row=[]
for i in range(m):
for j in range(n):
value=str(input(f'Nhập giá trị dòng {i+1}, cột {j+1}: '))
row.append(value)
matrix.append(row) # Thêm cả dòng vào matrix
row=[]
matrix_new=[] # Chuyển vị matrix
row_new=[]
for j in range(n):
row_new=[matrix[i][j] for i in range(m)]
matrix_new.append(row_new)
row_new=[]
print("MATRIX NEW CÁCH 2")
for row in matrix_new: # in ma trận
for value in row:
print(value, end="\t") # '/t' để tạo khoảng trắng thay tab
print()
func_2(m,n)
def Ketqua(a):
Day=[]
for i in range(0,Dong):
i=input()
if len(i.split())<phantu or i=="":
print("Danh sach hai chieu khong dung kich thuoc da khai bao!")
return None
Day.append(i)
for n in range(0,phantu):
Hang=[]
for x in Day:
Hang.append(x.split()[n])
print(*Hang)
cờ=False
try:
a=input("Nhập kích thước: ")
Dong,phantu=map(int,a.split())
cờ=True
except:
print("Dinh dang dau vao khong hop le!")
if cờ:
if Dong>0 and phantu>0:
Danhsach=Ketqua(a)
else:
print("Vui lòng nhập số nguyên dương")