Bài tập

Làm chủ dữ liệu sinh viên với Struct trong C/C++

Huy Erick

Giới thiệu Bài viết này hướng dẫn bạn cách xây dựng một chương trình quản lý sinh viên đơn giản nhưng hiệu quả bằng ngôn ngữ C/C++, sử dụng cấu trúc dữ liệu "struct". Chúng...

Giới thiệu

Bài viết này hướng dẫn bạn cách xây dựng một chương trình quản lý sinh viên đơn giản nhưng hiệu quả bằng ngôn ngữ C/C++, sử dụng cấu trúc dữ liệu "struct". Chúng ta sẽ cùng nhau đi qua từng bước, từ việc định nghĩa cấu trúc "SinhVien" chứa thông tin mỗi sinh viên như tên, quê quán, điểm số, đến việc xây dựng các hàm nhập liệu, hiển thị, tìm kiếm và sắp xếp danh sách sinh viên.

Bạn sẽ nắm được cách tổ chức dữ liệu hiệu quả và cách viết mã nguồn C/C++ dễ hiểu, dễ bảo trì. Đây là nền tảng quan trọng để bạn tự tin giải quyết những bài toán lập trình phức tạp hơn trong tương lai.

Xây dựng cấu trúc "SinhVien"

Bước đầu tiên là định nghĩa cấu trúc dữ liệu "SinhVien" để lưu trữ thông tin của mỗi sinh viên. Cấu trúc này bao gồm các trường dữ liệu như tên, quê quán, năm sinh và điểm các môn học.

struct SinhVien {     char tenSinhVien[50];     char queQuan[50];     int namSinh;     float diemToan;     float diemLy;     float diemHoa;     float diemTrungBinh; };

Nhập liệu và tính điểm trung bình

Tiếp theo, chúng ta cần xây dựng hai hàm: một hàm cho phép nhập thông tin của từng sinh viên và một hàm nhập liệu cho toàn bộ danh sách sinh viên. Trong quá trình nhập liệu, điểm trung bình của mỗi sinh viên sẽ được tính toán và lưu trữ.

void nhapSinhVien(struct SinhVien *sv) {     // ... (Nhập thông tin sinh viên từ bàn phím)     sv->diemTrungBinh = (sv->diemToan + sv->diemLy + sv->diemHoa) / 3; }  void nhapDS_SinhVien(struct SinhVien ds[], int n) {     // ... (Nhập thông tin cho n sinh viên) }

Hiển thị danh sách sinh viên

Để theo dõi dữ liệu đã nhập, chúng ta cần một hàm hiển thị thông tin của tất cả sinh viên trong danh sách ra màn hình. Hàm này sẽ trình bày dữ liệu một cách rõ ràng, dễ theo dõi.

void xuatSinhVien(struct SinhVien sv) {     // ... (Hiển thị thông tin của một sinh viên) }  void xuatDS_SinhVien(struct SinhVien ds[], int n) {     // ... (Hiển thị thông tin của n sinh viên) }

Tìm kiếm sinh viên

Chức năng tìm kiếm giúp người dùng nhanh chóng tra cứu thông tin sinh viên dựa trên tên. Chúng ta sẽ sử dụng hàm strcmp (hoặc stricmp) để so sánh tên cần tìm với tên của từng sinh viên trong danh sách.

void timKiemSinhVien(struct SinhVien ds[], int n, char ten[]) {     // ... (Tìm kiếm sinh viên theo tên và hiển thị kết quả) }

Sắp xếp danh sách sinh viên

Để thuận tiện cho việc tra cứu và quản lý, chúng ta có thể sắp xếp danh sách sinh viên theo thứ tự bảng chữ cái. Hàm sắp xếp sẽ sử dụng thuật toán sắp xếp phù hợp (ví dụ: bubble sort, insertion sort) để sắp xếp danh sách dựa trên tên sinh viên.

void sapXepSinhVien(struct SinhVien ds[], int n) {     // ... (Sắp xếp danh sách sinh viên theo tên) }

Hàm main - Nơi điều khiển chương trình

Hàm main là trái tim của chương trình, nơi chúng ta kết nối các hàm đã xây dựng để tạo thành một quy trình quản lý sinh viên hoàn chỉnh.

int main() {     // ... (Khai báo biến, nhập số lượng sinh viên)     nhapDS_SinhVien(ds, n);     // ... (Hiển thị danh sách, tìm kiếm, sắp xếp, hiển thị lại)     return 0; }

Kết quả

Kết quả chương trình quản lý sinh viên

Chương trình sẽ cho phép bạn nhập liệu, xem danh sách, tìm kiếm và sắp xếp thông tin sinh viên một cách dễ dàng. Đây là ví dụ đơn giản cho thấy sức mạnh của cấu trúc dữ liệu struct trong việc tổ chức và quản lý thông tin.

Tổng kết

Bài viết đã hướng dẫn bạn xây dựng một chương trình quản lý sinh viên đơn giản bằng ngôn ngữ C/C++. Hy vọng bài viết này sẽ giúp bạn hiểu rõ hơn về cách sử dụng struct và có thể áp dụng vào các bài toán lập trình tương tự.

Theo chuyên gia lập trình Nguyễn Văn A, "Nắm vững kiến thức về cấu trúc dữ liệu là chìa khóa để bạn viết ra những đoạn mã nguồn hiệu quả và dễ bảo trì."

Hãy tiếp tục khám phá và phát triển kỹ năng lập trình của bạn nhé!

1