VietTuts

Tự Học Lập Trình Online

  • Home
  • Java
  • Servlet
  • JSP
  • Struts2
  • Hibernate
  • Spring
  • MyBatis
  • Java WS
  • C
  • C++
  • C#
  • Python
  • PHP
  • Excel
  • VBA
  • Web
    • JavaScript
    • JQUERY
    • JSON
    • AJAX
    • CSS
    • HTML
    • HTML5
    • Node.js
    • Angular 7
  • SQL
    • MySQL
    • SQL Server
  • Misc
    • Eclipse
    • Phần mềm tiện ích
    • Cấu trúc DL&GT
    • Selenium Test
C Cơ Bản Chuỗi (String) Trong C Xử Lý File Trong C

Bài Tập C

Danh sách bài tập C Danh sách bài tập C++

Bài Tập C Kinh Điển

Dãy số Fibonacci trong C Check số nguyên tố trong C Tính giai thừa trong C Chuyển đổi hệ cơ số trong C

Bài Tập C Cơ Bản

Giải phương trình bậc 2 Tìm UCLN và BCNN Liệt kê tất cả số nguyên tố nhỏ hơn n Liệt kê n số nguyên tố đầu tiên Liệt kê tất cả số nguyên tố có 5 chữ số Phân tích số nguyên Tính tổng của các chữ số của một số nguyên Tìm số thuận nghịch Liệt kê số Fibonacci nhỏ hơn n là nguyên tố

Bài Tập Vòng Lặp C

Bài tập vòng lặp trong C Vẽ tam giác đều trong C Vẽ tam giác vuông cân trong C Vẽ tam giác Floyd trong C Vẽ tam giác Pascal trong C

Bài Tập Mảng Trong C

In mảng trong C Nhập mảng từ bàn phím trong C Tính tổng giá trị của một mảng trong C Tính giá trị trung bình của một mảng trong C Sao chép mảng trong C Chia một mảng thành hai mảng trong C Trộn hai mảng thành một mảng trong C

Bài Tập Mảng 2 Chiều Trong C

Nhập ma trận từ bàn phím trong C Trừ hai ma trận trong C Cộng hai ma trận trong C Tính tổng tất cả các phần tử của ma trận trong C

Bài tập chuỗi trong C

Nhập chuỗi từ bàn phím trong C Bài tập C - In chuỗi trong C Tìm độ dài chuỗi trong C Tìm số lần xuất hiện của một ký tự trong một chuỗi trong C Sắp xếp các ký tự của chuỗi theo thứ tự bảng chữ cái trong C Sao chép chuỗi trong C Đảo ngược chuỗi trong C Tìm kiếm chuỗi trong C So sánh hai chuỗi trong C Nối chuỗi trong C Đảo ngược các ký tự của từng từ của một chuỗi trong C Đảo ngược thứ tự từ của một chuỗi trong C Sắp xếp các chuỗi theo thứ tự chữ cái trong C Chuyển đổi chuỗi thành số nguyên trong C Biến đổi chuỗi thành chữ hoa trong C Biến đổi chuỗi thành chữ thường trong C

Bài tập về các thuật toán sắp xếp trong C

Sắp xếp nổi bọt (Bubble Sort) trong C Sắp xếp chọn (Selection Sort) trong C Sắp xếp chèn (Insertion Sort) trong C Sắp xếp nhanh (Quick Sort) trong C Sắp xếp trộn (Merge Sort) trong C Sắp xếp Shell Sort trong C

Bài Tập C Nâng Cao

Bài tập quản lý sinh viên trong C/C++
1 / 3
❮ ❯

Bài tập C - Sắp xếp nổi bọt (Bubble Sort) trong C


Bài tập C - Duyệt và in mảng bởi sử dụng con trỏ trong C
Bài tập C - Sắp xếp chọn (Selection Sort) trong C

Nội dung chính

  • Bài tập C - Sắp xếp nổi bọt (Bubble Sort) trong C
  • Lời giải

Bài tập C - Sắp xếp nổi bọt (Bubble Sort) trong C

Đề bài: Viết chương trình C sắp xếp một dãy số theo thứ tự tăng dần bằng thuật toán nổi bọt (Bubble Sort).


Lời giải

Sắp xếp nổi bọt (Bubble Sort) là một giải thuật sắp xếp đơn giản. Giải thuật sắp xếp này được tiến hành dựa trên việc so sánh cặp phần tử liền kề nhau và tráo đổi thứ tự nếu chúng không theo thứ tự.

Giải thuật này không thích hợp sử dụng với các tập dữ liệu lớn khi mà độ phức tạp trường hợp xấu nhất và trường hợp trung bình là Ο(n2) với n là số phần tử.

Giải thuật sắp xếp nổi bọt là giải thuật chậm nhất trong số các giải thuật sắp xếp cơ bản. Giải thuật này còn chậm hơn giải thuật đổi chỗ trực tiếp mặc dù số lần so sánh bằng nhau, nhưng do đổi chỗ hai phần tử kề nhau nên số lần đổi chỗ nhiều hơn.

Dưới đây là chương trình C để giải bài sắp xếp nổi bọt (Bubble Sort) trong C:


#include <stdio.h>
#include <stdbool.h>

#define MAX 10

int arr[MAX] = {6, 7, 0, 2, 8, 1, 3, 9, 4, 5};

void bubbleSort() {
    int temp;
    int i,j;

    bool swapped = false;
    
    // lap qua tat ca cac so
    for(i = 0; i < MAX-1; i++) { 
        swapped = false;

        // vong lap thu hai
        for(j = 0; j < MAX-1-i; j++) {
            printf("So sanh cac phan tu: [ %d, %d ] ", arr[j],arr[j+1]);

            // kiem xa xem so ke tiep co nho hon so hien tai hay khong
            // trao doi cac so. 
            // (Muc dich: lam noi bot (bubble) so lon nhat) 

            if(arr[j] > arr[j+1]) {
                temp = arr[j];
                arr[j] = arr[j+1];
                arr[j+1] = temp;

                swapped = true;
                printf(" => trao doi [%d, %d]\n", arr[j], arr[j+1]);
            } else {
                printf(" => khong can trao doi\n");
            }
        }

        // neu khong can trao doi nua, tuc la 
        // mang da duoc sap xep va thoat khoi vong lap. 
        if(!swapped) {
            break;
        }
        
        printf("Vong lap thu %d#: ", (i+1));
        display();
    }
}

void display() {
    int i;
    printf("[");

    // Duyet qua tat ca phan tu
    for(i = 0; i < MAX; i++){
        printf("%d ", arr[i]);
    }

    printf("]\n");
}

main(){
    printf("Mang du lieu dau vao: ");
    display();
    printf("-----------------------------\n");
    bubbleSort();
    printf("-----------------------------\n");
    printf("\nMang sau khi da sap xep: ");
    display();
}

Chạy chương trình C trên cho kết quả như sau:

Sắp xếp nổi bọt (Bubble Sort) trong C
Bài tập C - Duyệt và in mảng bởi sử dụng con trỏ trong C
Bài tập C - Sắp xếp chọn (Selection Sort) trong C

Recent Updates

Xuất dữ liệu ra màn hình console trong JavaCài đặt môi trường JavaLinkedList trong javaArrayList trong javaXử lý duplicate trong SQLPhím tắt hay dùng trong ExcelBảo mật tập tin ExcelDịch trang tính trong ExcelIn trang tính trong ExcelHàm VLOOKUP trong ExcelĐối tượng đồ họa trong ExcelSử dụng macro trong ExcelSắp Tết 2026 Rồi! - Còn bao nhiêu ngày nữa là đến tết 2026?

VietTuts on facebook

Học Lập Trình Online Miễn Phí - VietTuts.Vn
Danh Sách Bài Học

Học Java | Hibernate | Spring
Học Excel | Excel VBA
Học Servlet | JSP | Struts2
Học C | C++ | C#
Học Python
Học SQL

Bài Tập Có Lời Giải

Bài tập Java
Bài tập C
Bài tập C++
Bài tập C#
Bài tập Python
Ví dụ Excel VBA

Câu Hỏi Phỏng Vấn

201 câu hỏi phỏng vấn java
25 câu hỏi phỏng vấn servlet
75 câu hỏi phỏng vấn jsp
52 câu hỏi phỏng vấn Hibernate
70 câu hỏi phỏng vấn Spring
57 câu hỏi phỏng vấn SQL

Scroll back to top

Copyright © 2016 VietTuts.Vn all rights reserved. | Liên hệ | Chính sách - riêng tư | sitemap.html | sitemap_index.xml