Sắp xếp mảng tăng / giảm dần bằng Python
Hãy viết chương trình Python sắp xếp các phần tử trong mảng theo thứ tự tăng dần và giảm dần, danh sách các phần tử do người dùng nhập vào và đó phải là danh sách các số nguyên.
Bài giải
-------------------- ######## --------------------
Qua bài tập sắp xếp mảng Python này sẽ giúp bạn hiểu được thuật toán sắp xếp nổi bọt, bằng cách sử dụng hai vòng lặp for lồng nhau để sắp xếp thứ tự cho chúng.

Thuật toán này khá đơn giản cho trường hợp sắp xếp tăng dần như sau:
- Vòng lặp 1 sẽ lặp qua lần lượt các phần tử trong mảng,
- Mỗi lần lặp sẽ lặp tiếp các phần tử phía sau bằng cách sử dụng thêm một vòng lặp nữa,
- Nếu có phần tử phía sau nào bé hơn phần tử đang lặp ở vòng 1 thì đổi vị trí cho chúng.
- Cứ như vậy cho tới khi vòng lặp 1 kết thúc thì ta thu được kết quả
Trường hợp sắp xếp giảm dần thì ta chỉ cần đổi điều kiện từ bé hơn sang lớn hơn.
Để đơn giản hóa thì trong bài giải này mình chỉ làm trường hợp sắp xếp tăng dần thôi nhé.
Bài viết này được đăng tại [free tuts .net]
Xem chương trình mẫu dưới đây:
# SẮP XẾP TĂNG DẦN
numbers = [3,45,2,46,5,25,65,8,57,67]
lenth = len(numbers)
# Lặp từ phần tử đầu đến kế cuối,
# Vì khi đến phần tử cuối là đã sắp xếp thànhcông
for i in range(0, lenth - 1):
for j in range(i + 1, lenth):
if (numbers[i] > numbers[j]):
# Hoán đổi vị trí
tmp = numbers[i]
numbers[i] = numbers[j]
numbers[j] = tmp
print(numbers)
# Kết quả: [2, 3, 5, 8, 25, 45, 46, 57, 65, 67]Áp dụng vào chương trình chính:
# Học Python tại Freetuts.net
# Author: Cường Nguyễn
# SẮP XẾP TĂNG DẦN
def sap_xep_tang_dan(numbers):
lenth = len(numbers)
# Lặp từ phần tử đầu đến kế cuối,
# Vì khi đến phần tử cuối là đã sắp xếp thànhcông
for i in range(0, lenth - 1):
for j in range(i + 1, lenth):
if (numbers[i] > numbers[j]):
# Hoán đổi vị trí
tmp = numbers[i]
numbers[i] = numbers[j]
numbers[j] = tmp
return numbers
# Chương trình chính
print("Chương trình sắp xếp mảng Python")
print("Bạn muốn tạo mảng có bao nhiêu phần tử", end=":")
length = int(input())
numbers = []
for i in range(0, length):
print("Nhập phần tử thứ ", (i + 1), end=":")
numbers.append(int(input()))
print("Mảng trước khi sắp xếp")
print(numbers)
print("Mảng sau khi sắp xếp")
print(sap_xep_tang_dan(numbers))
Chạy lên kết quả sẽ như sau:
Câu hỏi thường gặp liên quan:
- In ra các số chẵn trong mảng bằng Python
- Tìm kiếm phần tử trong mảng bằng Python
- Sự khác nhau giữa mảng, tuple, dictionary và set trong Python
- Sắp xếp mảng tăng / giảm dần bằng Python
- Chương trình quản lý sinh viên Python lưu mảng và dictionary

Các kiểu dữ liệu trong C ( int - float - double - char ...)
Thuật toán tìm ước chung lớn nhất trong C/C++
Cấu trúc lệnh switch case trong C++ (có bài tập thực hành)
ComboBox - ListBox trong lập trình C# winforms
Random trong Python: Tạo số random ngẫu nhiên
Lệnh cin và cout trong C++
Cách khai báo biến trong PHP, các loại biến thường gặp
Download và cài đặt Vertrigo Server
Thẻ li trong HTML
Thẻ article trong HTML5
Cấu trúc HTML5: Cách tạo template HTML5 đầu tiên
Cách dùng thẻ img trong HTML và các thuộc tính của img
Thẻ a trong HTML và các thuộc tính của thẻ a thường dùng