/*auto readmore*/ /*auto readmore*/ /* an hien script*/ // an hien password /*an hien ma chuong trinh cong tru */ /*Scrollbox thanh cuon*/ /***Nhung CODE***/ /* dòng xanh dòng trắng */ /* https://cdnjs.com/libraries/prism lay thu vien, can vao ten file ma goi 1. copy link vao vi du:prism-python.min.js 2. ten ngon nua la python */ /*=== New posts ===*/ /*header slider*/ /*=== bai viet lien quan===*/ /*===tabcode===*/

[Tự Học Lập Trình C - Qua Các Bài Tập] COM108_Nhập Môn Lập Trình - Bài 8 - Cấu Trúc (Structure) Trong C - P2 - Ôn Tập

NỘI DUNG:
Ôn tập các kiến thức liên quan đến cấu trúc (struct) trong C

YÊU CẦU:

Tìm hiểu lý thuyết rước khi xem bài này

BÀI 1:
Tạo struct PhanSo với 2 trường dữ liệu là tuSo và mauSo. Xây dựng các hàm:
  • Nhập phân số,
  • Xuất phân số,
  • Tìm ước số chung lớn nhất,
  • Rút gọn phân số.
Input: Nhập phân số (tử số và mẫu số) từ bàn phím
Output: In ra phân số đã rút gọn.

BÀI 2:
Tạo struct PhanSo với 2 trường dữ liệu là tuSo và mauSo. Xây dựng các hàm:
  • Nhập phân số,
  • Xuất phân số,
  • Tính tổng 2 phân số,
  • Tính tích 2 phân số,
  • Tính thương 2 phân số.
Input: Nhập phân số (tử số và mẫu số) từ bàn phím
Output: Xuất tổng, thương, tích

BÀI 3:
Xây dựng hàm các nhập và xuất phân số
Input: 
- Nhập n (số lượng phân số cần nhập) từ bàn phím,
- Nhập vào các phân số theo số lượng n
Output: Xuất ra tất cả các phân số vừa nhập

BÀI 4:
Tạo struct SinhVien với các trường thông tin: họ tên, điểm. Xây dựng các hàm:
  • Nhập thông tin sinh viên
  • Xuất thông tin sinh viên
  • Sắp xếp giảm dần theo cột/trường dữ liệu điểm
Input: Nhập vào họ tên, điểm của sinh viên
Output: 
Hiển thị ra thông tin sinh viên, điểm, học lực (1 sinh viên)
- Hiển thị ra thông tin sinh viên, điểm, học lực, sắp xếp theo thứ tự điểm giảm dần (danh sách sinh viên)

BÀI 5:
Tạo struct NhanVien với các trường thông tin: mã nhân viên, tên nhân viên, lương căn bản. Xây dựng các hàm:
  • Nhập thông tin nhân viên
  • Xuất danh sách nhân viên
  • Sắp xếp tên theo thứ tự từ a đến z
  • Sắp xếp mức lương căn bản theo thứ tự giảm dần
  • Và một số hàm khác nếu cần thiết
Input: Nhập thông tin cho n nhân viên, n là số lượng nhân viên
Output: 
- Hiển thị thông tin nhân viên theo tên đã sắp xếp theo yêu cầu xây dựng hàm
- Hiển thị thông tin nhân viên theo mức lương căn bản đã sắp xếp theo yêu cầu xây dựng hàm
- Hiển thị thông tin 2 nhân viên có mức lương cao nhất.
- Hiển thi thông tin 1 nhân viên có mức lương cao/thấp nhất.


THỰC HIỆN

BÀI 1:
Tạo struct PhanSo với 2 trường dữ liệu là tuSo và mauSo. Xây dựng các hàm:
  • Nhập phân số,
  • Xuất phân số,
  • Tìm ước số chung lớn nhất,
  • Rút gọn phân số.
Input: Nhập phân số (tử số và mẫu số) từ bàn phím
Output: In ra phân số đã rút gọn.

Code:
#include<stdio.h>

struct PhanSo{
	int tuSo;
	int mauSo;

};

typedef struct PhanSo PS;

int uCLN(int a, int b){
	if (a == 0 || b == 0) return a + b;
	while ( a != b){
		if ( a > b) 
//			a = a - b;
			a -= b;
		else 
			b -= a;
	}return a;
}

void rutGonPhanSo(PS &ps){ // cả tử và mẫu cùng chia hết cho ước số chung lớn nhất
	int uocSo = uCLN(ps.tuSo, ps.mauSo);
	ps.mauSo = ps.mauSo / uocSo;
	ps.tuSo = ps.tuSo / uocSo;
}

void nhapPhanSo(PS &ps){
	printf("\nNhap TU so: ");
	scanf("%d", &ps.tuSo);
	printf("\nNhap MAU so: ");
	scanf("%d", &ps.mauSo);
}

void xuatPhanSo(PS ps){
	rutGonPhanSo(ps); // rút gọn rồi mới in ra
	printf("\n%d/%d", ps.tuSo, ps.mauSo);
}

int main(){
	
	PS ps;

	nhapPhanSo(ps);
//	rutGonPhanSo(ps);
	xuatPhanSo(ps);
	
}


BÀI 2:
Tạo struct PhanSo với 2 trường dữ liệu là tuSo và mauSo. Xây dựng các hàm:
  • Nhập phân số,
  • Xuất phân số,
  • Tính tổng 2 phân số,
  • Tính tích 2 phân số,
  • Tính thương 2 phân số.
Input: Nhập phân số (tử số và mẫu số) từ bàn phím
Output: Xuất tổng, thương, tích

Code:
#include<stdio.h>
struct PhanSo{
	int tuSo;
	int mauSo;
};

typedef struct PhanSo PS;

void nhapPhanSo(PS &a){
	printf("\nNhap TU so: "); scanf("%d", &a.tuSo);
	printf("\nNhap MAU so: "); scanf("%d", &a.mauSo);
}

void xuatPhanSo(PS a){
	printf("%d/%d", a.tuSo, a.mauSo); 
}

PS tongPhanSo(PS a, PS b){
	PS tong;
	tong.tuSo = (a.tuSo * b.mauSo) + (b.tuSo * b.mauSo); // hieu thay + thanh tru
	tong.mauSo = a.mauSo * b.mauSo;
	return tong;
}

PS tichPhanSo(PS a, PS b){ 
	PS tich;
	tich.mauSo = a.mauSo * b.mauSo;
	tich.tuSo = a.tuSo * b.tuSo;
	return tich;
}

PS thuongPhanSo(PS a, PS b){ 
	PS thuong;
	thuong.tuSo = a.tuSo * b.mauSo;
	thuong.mauSo = a.mauSo * b.tuSo;
	return thuong;
}

int main(){
	
	PS ps1, ps2;
	nhapPhanSo(ps1);
	nhapPhanSo(ps2);
	printf("\nTong 2 phan so la: ");
	xuatPhanSo(tongPhanSo(ps1, ps2));
	printf("\nTich 2 phan so la: ");
	xuatPhanSo(tichPhanSo(ps1, ps2));
	printf("\nThuong 2 phan so la: ");
	xuatPhanSo(thuongPhanSo(ps1, ps2));
}

BÀI 3:
Xây dựng hàm các nhập và xuất phân số
Input: 
- Nhập n (số lượng phân số cần nhập) từ bàn phím,
- Nhập vào các phân số theo số lượng n
Output: Xuất ra tất cả các phân số vừa nhập

Code:
#include<stdio.h>

struct PhanSo{
	int tuSo;
	int mauSo;

};

typedef struct PhanSo PS;

void nhapPhanSo(PS &ps){
	printf("\nNhap TU so: ");
	scanf("%d", &ps.tuSo);
	printf("\nNhap MAU so: ");
	scanf("%d", &ps.mauSo);
}

void xuatPhanSo(PS ps){
	printf("\n%d/%d", ps.tuSo, ps.mauSo);
}

int main(){
	
	PS ps[100]; // mảng một chiều
	int n, i;
	
	printf("\nNhap vao SO LUONG phan so can nhap: ");
	scanf("%d", &n);
	for(i = 0; i < n; i++) nhapPhanSo(ps[i]);
	
	printf("\nCac phan so vua nhap la: ");
	for(i = 0; i < n; i++) xuatPhanSo(ps[i]);
	
}

BÀI 4:
Tạo struct SinhVien với các trường thông tin: họ tên, điểm. Xây dựng các hàm:
  • Nhập thông tin sinh viên
  • Xuất thông tin sinh viên
  • Sắp xếp giảm dần theo cột/trường dữ liệu điểm
Input: Nhập vào họ tên, điểm của sinh viên
Output: 
Hiển thị ra thông tin sinh viên, điểm, học lực (1 sinh viên)

Code:
#include<stdio.h>

struct SinhVien{
	char tenSinhVien[50];
	float diemTrungBinh;

};

typedef struct SinhVien SV;

void xepLoai(SV sv){
	printf("\nHoc luc: ");
	if (sv.diemTrungBinh >= 9){
		printf ("Xuat sac!");
	} else if (sv.diemTrungBinh >= 8){
		printf ("Gioi!");
	} else if (sv.diemTrungBinh >= 6.5){
		printf ("Kha!");
	} else if (sv.diemTrungBinh >= 5){
		printf ("Trung binh!");
	} else printf ("Yeu!");
}

void xepLoaiVietGon(SV sv){ // tương tự hàm xepLoai, có thể dùng 1 trong 2 hàm
	printf("\nHoc luc: ");
	if (sv.diemTrungBinh >= 9) printf ("Xuat sac!");
	else if (sv.diemTrungBinh >= 8) printf ("Gioi!");
	else if (sv.diemTrungBinh >= 6.5) printf ("Kha!");
	else if (sv.diemTrungBinh >= 5)	printf ("Trung binh!");
	else printf ("Yeu!");
}

void nhapSinhVien(SV &sv){
	printf("\nNhap ten sinh vien: "); 
//	getchar();
	fflush(stdin);
	gets(sv.tenSinhVien);
	printf("\nNhap diem trung binh: ");
	scanf("%f", &sv.diemTrungBinh);
}

void xuatSinhVien(SV sv){
	printf("\nTen sinh vien: %s", sv.tenSinhVien);
	printf("\nDiem trung binh: %.2f", sv.diemTrungBinh);
	xepLoai(sv);
}

int main(){
	
	SV sv;
	nhapSinhVien(sv);
	xuatSinhVien(sv);
	
}


- Hiển thị ra thông tin sinh viên, điểm, học lực, sắp xếp theo thứ tự điểm giảm dần (danh sách sinh viên)

Code:
#include<stdio.h>

struct SinhVien{
	char tenSinhVien[50];
	float diemTrungBinh;

};

typedef struct SinhVien SV;

void xepLoai(SV sv){
	printf(" Hoc luc: ");
	if (sv.diemTrungBinh >= 9){
		printf ("Xuat sac!");
	} else if (sv.diemTrungBinh >= 8){
		printf ("Gioi!");
	} else if (sv.diemTrungBinh >= 6.5){
		printf ("Kha!");
	} else if (sv.diemTrungBinh >= 5){
		printf ("Trung binh!");
	} else printf ("Yeu!");
}

void xepLoaiVietGon(SV sv){
	printf("\nHoc luc: ");
	if (sv.diemTrungBinh >= 9) printf ("Xuat sac!");
	else if (sv.diemTrungBinh >= 8) printf ("Gioi!");
	else if (sv.diemTrungBinh >= 6.5) printf ("Kha!");
	else if (sv.diemTrungBinh >= 5)	printf ("Trung binh!");
	else printf ("Yeu!");
}

void nhapSinhVien(SV &sv){
	printf("\nNhap ten sinh vien: "); 
//	getchar();
	fflush(stdin);
	gets(sv.tenSinhVien);
	printf("\nNhap diem trung binh: ");
	scanf("%f", &sv.diemTrungBinh);
}

void nhapSinhVienDS(SV sv[], int n){
	for (int i = 0; i < n; i++){
		printf("\nNhap thong tin sinh vien thu %d ", i + 1);
		nhapSinhVien(sv[i]);
	}
}

void xuatSinhVien_BanDau(SV sv){
	printf("\nTen sinh vien: %s", sv.tenSinhVien);
	printf("Diem trung binh: %.2f", sv.diemTrungBinh);
	xepLoai(sv);
}

void xuatSinhVien(SV sv){
	printf("\nTen sinh vien: %s", sv.tenSinhVien);
	printf(" Diem trung binh: %.2f", sv.diemTrungBinh);
	xepLoai(sv);
}

void xuatSinhVienDS(SV sv[], int n){
	for (int i = 0; i < n; i++){
		printf("\nThong tin sinh thu %d ", i + 1);
		xuatSinhVien(sv[i]);
	}
}

void sapXep(SV sv[], int n){
	int i, j;
	for (i = 0; i < n - 1; i++){
		for (j = i + 1; j < n; j++){
			if (sv[i].diemTrungBinh < sv[j].diemTrungBinh){
				SV svtmp;
				svtmp = sv[i];
				sv[i] = sv[j];
				sv[j] = svtmp;
			}
		}
	}
}

int main(){
	int n;
	printf("\nNhap so luong sinh vien can them thong tin: ");
	scanf("%d", &n);
	SV sv[n];
	
	nhapSinhVienDS(sv, n);
	sapXep(sv, n);
	xuatSinhVienDS(sv, n);	
}

BÀI 5:
Tạo struct NhanVien với các trường thông tin: mã nhân viên, tên nhân viên, lương căn bản. Xây dựng các hàm:
  • Nhập thông tin nhân viên
  • Xuất danh sách nhân viên
  • Sắp xếp tên theo thứ tự từ a đến z
  • Sắp xếp mức lương căn bản theo thứ tự giảm dần
  • Và một số hàm khác nếu cần thiết
Input: Nhập thông tin cho n nhân viên, n là số lượng nhân viên
Output: 
- Hiển thị thông tin nhân viên theo tên đã sắp xếp theo yêu cầu xây dựng hàm
- Hiển thị thông tin nhân viên theo mức lương căn bản đã sắp xếp theo yêu cầu xây dựng hàm
- Hiển thị thông tin 2 nhân viên có mức lương cao nhất.
- Hiển thi thông tin 1 nhân viên có mức lương cao/thấp nhất.
Nhập xuất một nhân viên
#include<stdio.h>

struct NhanVien{
	char maNhanVien[20];
	char tenNhanVien[50];
	int luongCanBan;
};
typedef struct NhanVien NV;

void nhapNhanVien(NV &nv){
	printf("Nhap ma NV: ");
	scanf("%s", &nv.maNhanVien);//vi ko co khoang trang
	printf("Nhap ten NV: "); 
	fflush(stdin);
	gets(nv.tenNhanVien);
	printf("Nhap muc luong can ban: ");
	scanf("%d", &nv.luongCanBan);
}

void xuatNhanVien(NV nv){
	printf("\nMa NV: %s", nv.maNhanVien);
	printf("\nTen NV: %s", nv.tenNhanVien);
	printf("\nLuong can ban: %d", nv.luongCanBan);
	printf("\n");
}
int main(){

	NV nv;
	nhapNhanVien(nv);
	xuatNhanVien(nv);
}
Nhập xuất n nhân viên
#include<stdio.h>

struct NhanVien{
	char maNhanVien[20];
	char tenNhanVien[50];
	int luongCanBan;
};
typedef struct NhanVien NV;

void nhapNhanVien(NV &nv){
	printf("Nhap ma NV: ");
	scanf("%s", &nv.maNhanVien);//vi ko co khoang trang
	printf("Nhap ten NV: "); 
	fflush(stdin);
	gets(nv.tenNhanVien);
	printf("Nhap muc luong can ban: ");
	scanf("%d", &nv.luongCanBan);
}

void xuatNhanVien(NV nv){
	printf("\nMa NV: %s", nv.maNhanVien);
	printf("\nTen NV: %s", nv.tenNhanVien);
	printf("\nLuong can ban: %d", nv.luongCanBan);
	printf("\n");
}

void nhapNhanVienDS(NV nv[], int n){
	for (int i = 0; i < n; i++){
		printf("\nNhap thong tin NV thu %d!\n", i + 1);
		nhapNhanVien(nv[i]);
	}
}

void xuatNhanVienDS(NV nv[], int n){
	for (int i = 0; i < n; i++){
		printf("\nNhap thong tin NV thu %d!", i + 1);
		xuatNhanVien(nv[i]);
	} 
}

int main(){

	int n;
	printf("\nNhap so luong NV can them: ");
	scanf("%d", &n);
	
	NV nv[n];
	nhapNhanVienDS(nv, n);
	xuatNhanVienDS(nv, n);
}
Nhập n nhân viên, xuất danh sách nhân viên đã sắp xếp mức lương căn bản theo thứ tự giảm dần
#include<stdio.h>

struct NhanVien{
	char maNhanVien[20];
	char tenNhanVien[50];
	int luongCanBan;
};
typedef struct NhanVien NV;

void nhapNhanVien(NV &nv){
	printf("Nhap ma NV: ");
	scanf("%s", &nv.maNhanVien);//vi ko co khoang trang
	printf("Nhap ten NV: "); 
	fflush(stdin);
	gets(nv.tenNhanVien);
	printf("Nhap muc luong can ban: ");
	scanf("%d", &nv.luongCanBan);
}

void xuatNhanVien(NV nv){
	printf("\nMa NV: %s", nv.maNhanVien);
	printf("\nTen NV: %s", nv.tenNhanVien);
	printf("\nLuong can ban: %d", nv.luongCanBan);
	printf("\n");
}

void nhapNhanVienDS(NV nv[], int n){
	for (int i = 0; i < n; i++){
		printf("\nNhap thong tin NV thu %d!\n", i + 1);
		nhapNhanVien(nv[i]);
	}
}

void xuatNhanVienDS(NV nv[], int n){
	for (int i = 0; i < n; i++){
		printf("\nNhap thong tin NV thu %d!", i + 1);
		xuatNhanVien(nv[i]);
	} 
}
void hoanVi(NV &nv1, NV &nv2){
	NV temp;
	temp = nv1;
	nv1 = nv2;
	nv2 = temp;
}

void sapXep_DangSo(NV nv[], int n){
	for (int i = 0; i < n - 1; i++){
		for (int j = i + 1; j < n; j++){
			if (nv[i].luongCanBan < nv[j].luongCanBan){
				hoanVi(nv[i], nv[j]);
			}
		}
	}
}

int main(){

	int n;
	printf("\nNhap so luong NV can them: ");
	scanf("%d", &n);
	
	NV nv[n];
	nhapNhanVienDS(nv, n);
	sapXep_DangSo(nv, n);
	xuatNhanVienDS(nv, n);
}
Nhập n nhân viên, xuất danh sách nhân viên đã sắp xếp tên theo thứ tự từ a đến z
#include<stdio.h>
#include<string.h>
struct NhanVien{
	char maNhanVien[20];
	char tenNhanVien[50];
	int luongCanBan;
};
typedef struct NhanVien NV;

void nhapNhanVien(NV &nv){
	printf("Nhap ma NV: ");
	scanf("%s", &nv.maNhanVien);//vi ko co khoang trang
	printf("Nhap ten NV: "); 
	fflush(stdin);
	gets(nv.tenNhanVien);
	printf("Nhap muc luong can ban: ");
	scanf("%d", &nv.luongCanBan);
}

void xuatNhanVien(NV nv){
	printf("\nMa NV: %s", nv.maNhanVien);
	printf("\nTen NV: %s", nv.tenNhanVien);
	printf("\nLuong can ban: %d", nv.luongCanBan);
	printf("\n");
}

void nhapNhanVienDS(NV nv[], int n){
	for (int i = 0; i < n; i++){
		printf("\nNhap thong tin NV thu %d!\n", i + 1);
		nhapNhanVien(nv[i]);
	}
}

void xuatNhanVienDS(NV nv[], int n){
	for (int i = 0; i < n; i++){
		printf("\nNhap thong tin NV thu %d!", i + 1);
		xuatNhanVien(nv[i]);
	} 
}
void hoanVi(NV &nv1, NV &nv2){
	NV temp;
	temp = nv1;
	nv1 = nv2;
	nv2 = temp;
}

void sapXep_DangChuoi(NV nv[], int n){
	for (int i = 0; i < n - 1; i++){
		for (int j = i + 1; j < n; j++){
			if (strcmp(nv[i].tenNhanVien, nv[j].tenNhanVien) > 0){
				hoanVi(nv[i], nv[j]);
			}
		}
	}
		
}

int main(){

	int n;
	printf("\nNhap so luong NV can them: ");
	scanf("%d", &n);
	
	NV nv[n];
	nhapNhanVienDS(nv, n);
	sapXep_DangChuoi(nv, n);
	xuatNhanVienDS(nv, n);
}
Hiển thị thông tin 2 nhân viên có mức lương cao nhất.
Trên cơ sở mức lương đã sắp xếp chúng ta gọi hàm xuất 2 nhân viên là được
xuatNhanVienDS(nv, 2);
Hiển thi thông tin 1 nhân viên có mức lương cao/thấp nhất.
void timLuong_Max(NV nv[], int n){
	NV maxLuongNV = nv[0];
	int viTriMax = 0;
	int maxLuong = nv[0].luongCanBan;
	for (int i = 0; i < n; i++){
		if (nv[i].luongCanBan > maxLuong){ // tùy yêu cầu mà thay đổi dấu của biểu thức so sánh
			maxLuongNV = nv[i];
			viTriMax = i; // lưu vị trí thỏa điều kiện
		}	
	}
	xuatNhanVien(nv[viTriMax]);
}


Xong!

[Tự Học Lập Trình C - Qua Các Bài Tập] COM108_Nhập Môn Lập Trình - Bài 8 - Cấu Trúc (Structure) Trong C - P1

MỤC TIÊU:
  • Biết cách định nghĩa kiểu dữ liệu cấu trúc
  • Biết cách sử dụng thuật toán sắp xếp, tìm kiếm

LÝ THUYẾT:


Cấu trúc hay struct:
  • Một kiểu dữ liệu do người dùng tự định nghĩa (user defined datatype), cho phép bạn kết hợp các dữ liệu khác kiểu nhau.
  • Mỗi phần tử của một cấu trúc được gọi là một thành viên (member).

Khởi tạo:
  • Khởi tạo structure bằng cách sử dụng từ khóa struct.
  • Struct có dạng:
struct <structure_name>
{
   data_type member1;
   data_type member2;
    ...
   data_type memeberN;
} [một hoặc nhiều biến cấu trúc];

Ví dụ: Tạo cấu trúc có tên SinhVien gồm các trường dữ liệu: maSinhVien, tenSinhVien, diemTrungBinh;
Code:
struct SinhVien{
	char maSinhVien[10];
	char tenSinhVien[50];
	float diemTrungBinh;
};

Khai báo trong hàm main:
#include<stdio.h>
struct SinhVien{
	char maSinhVien[10];
	char tenSinhVien[50];
	float diemTrungBinh;
};

int main(){
	struct SinhVien a;
}

Khai báo dùng alias:
#include<stdio.h>
struct SinhVien{
	char maSinhVien[10];
	char tenSinhVien[50];
	float diemTrungBinh;
};

typedef struct SinhVien SV;

int main(){
	SV a;
}

Cách truy cập:
Truy cập các thành viên trong struct sử dụng dấu chấm (.), nếu viết dạng con trỏ thì sử dụng dấu trừ + mũi tên  "->"

Ví dụ 1:
#include<stdio.h>
struct SinhVien{
	char maSinhVien[8];
	char tenSinhVien[50];
	float diemTrungBinh;
};

typedef struct SinhVien SV;

int main(){
	SV a = {"PS12345", "Nguyen Van A", 8.5};
	printf ("\nThong tin sinh vien 'a'");
	printf ("\nMa so SV: %s", a.maSinhVien);
	printf ("\nHo ten SV: %s", a.tenSinhVien);
	printf ("\nDiem trung binh cac mon: %.1f", a.diemTrungBinh);
	
}

Ví dụ 2: Chỉ hoạt động trên C (lưu file .C), KHÔNG chạy trên C++
#include<stdio.h>
struct SinhVien{
	char maSinhVien[8];
	char tenSinhVien[50];
	float diemTrungBinh;
};

typedef struct SinhVien SV;

int main(){
	// cách khai báo này chỉ hoạt động trên C, KHÔNG chạy trên C++
	SV b = {.maSinhVien = "PS56789", .tenSinhVien = "Nguyen Van B", .diemTrungBinh = 9.5};
	printf ("\n\nThong tin sinh vien 'b'");
	printf ("\nMa so SV: %s", b.maSinhVien);
	printf ("\nHo ten SV: %s", b.tenSinhVien);
	printf ("\nDiem trung binh cac mon: %.1f", b.diemTrungBinh);	
}

Ví dụ 3: 
  • Cú pháp bị lỗi: [Error] assignment to expression with array type
int main(){
	
	SV c;
	c.maSinhVien = "PS99999";
	c.tenSinhVien = "Tony Teo";
}

  • Hướng khắc phục: Gán giá trị thành chuỗi, sử dụng hàm strcpy
int main(){
	
	SV c;
	strcpy(c.maSinhVien, "PS99999");
	strcpy(c.tenSinhVien, "Tony Teo");
}

Full code:
#include<stdio.h>
struct SinhVien{
	char maSinhVien[8];
	char tenSinhVien[50];
	float diemTrungBinh;
};

typedef struct SinhVien SV;

int main(){
	
	SV c;
	strcpy(c.maSinhVien, "PS99999");
	strcpy(c.tenSinhVien, "Tony Teo");
	c.diemTrungBinh = 9.5;
	
	printf ("\n\nThong tin sinh vien 'c'");
	printf ("\nMa so SV: %s", c.maSinhVien);
	printf ("\nHo ten SV: %s", c.tenSinhVien);
	printf ("\nDiem trung binh cac mon: %.1f", c.diemTrungBinh);	
}

Ví dụ: 
Viết chương trình nhập thông tin sinh viên bao gồm các trường: maSinhVien, tenSinhVien, diemTrungBinh
Input: Nhập thông tin maSinhVien, tenSinhVien, diemTrungBinh từ bàn phím
Output: Xuất ra thông tin sinh viên vừa nhập

a. Viết thông thường:
#include<stdio.h>
struct SinhVien{
	char maSinhVien[8];
	char tenSinhVien[50];
	float diemTrungBinh;
};

typedef struct SinhVien SV;

int main(){
	
	SV sv;
	printf("\nNhap ma so SV: "); scanf("%s", &sv.maSinhVien);
	
	printf("\nNhap ho ten SV: "); 
	getchar(); // để đọc phím enter, nếu không có sẽ trôi lệnh gets
	//fflush(stdin); // xóa vùng nhớ đệm
        gets(sv.tenSinhVien);// đọc chuỗi nhập từ bàn phím, CHẤP NHẬN chuỗi có khoảng trắng
	
	printf("\nNhap diem trung binh: "); scanf("%f", &sv.diemTrungBinh);
	
	printf ("\n\nThong tin sinh vien:");
	printf ("\nMa so SV: %s", sv.maSinhVien);
	printf ("\nHo ten SV: %s", sv.tenSinhVien);
	printf ("\nDiem trung binh cac mon: %.1f", sv.diemTrungBinh);	

} 
Noted:
  • getchar(); để đọc phím enter, nếu không có sẽ trôi lệnh gets
  • có thể dùng fflush(stdin) thay vì getchar(); để xóa vùng nhớ đệm
  • gets(sv1.tenSinhVien); đọc chuỗi nhập từ bàn phím, CHẤP NHẬN chuỗi có khoảng trắng
  • scanf("%[^\n]s", &tenBien); đọc chuỗi nhập từ bàn phím, CHẤP NHẬN chuỗi có khoảng trắng
b. Viết dạng hàm:

Có thể dùng SV thay vì SinhVien (dùng alias)
#include<stdio.h>
struct SinhVien{
	char maSinhVien[8];
	char tenSinhVien[50];
	float diemTrungBinh;
};

typedef struct SinhVien SV;
		
Muốn truy cập vào các thành viên của struct dùng dấu chấm (.)
void xuatSinhVien(SV sv){
	printf ("\n\nThong tin sinh vien:");
	printf ("\nMa so SV: %s", sv.maSinhVien);
	printf ("\nHo ten SV: %s", sv.tenSinhVien);
	printf ("\nDiem trung binh cac mon: %.1f", sv.diemTrungBinh);
}
		
Hàm nhập dạng trả về struct
SV nhapSinhVien(){
	SV sv;
	printf("\nNhap ma so SV: "); scanf("%s", &sv.maSinhVien);
	
	printf("\nNhap ho ten SV: "); 
	getchar();

	gets(sv.tenSinhVien);
	printf("\nNhap diem trung binh: "); scanf("%f", &sv.diemTrungBinh);
	return sv;
}
		
Hàm nhập trên C++ (lưu file file .CPP)
void nhapSinhVien_CPP(SV &sv){
	printf("\nNhap ma so SV: "); scanf("%s", &sv.maSinhVien);
	
	printf("\nNhap ho ten SV: "); 
	getchar();

	gets(sv.tenSinhVien);
	printf("\nNhap diem trung binh: "); scanf("%f", &sv.diemTrungBinh);
}
		
Hàm nhập dạng con trỏ: (sử dụng dấu trừ + dấu lớn "->")
void nhapSinhVienConTro(SV *sv){
	printf("\nNhap ma so SV: "); scanf("%s", &sv->maSinhVien);
	
	printf("\nNhap ho ten SV: "); 
	getchar();

	gets(sv->tenSinhVien);
	printf("\nNhap diem trung binh: "); scanf("%f", &sv->diemTrungBinh);
}
		
Hàm chính của chương trình
int main(){

//	SV sv = nhapSinhVien(); // gọi hàm nhập viết dạng trả về cấu trúc
	SV sv;
	nhapSinhVien_CPP(sv); // gọi hàm nhập viết dạng C++
//	nhapSinhVienConTro(&sv); // gọi hàm nhập viết dạng con trỏ

	xuatSinhVien(sv);	
}
		



YÊU CẦU:

BÀI 1: XÂY DỰNG CHƯƠNG TRÌNH LƯU THÔNG TIN SINH VIÊN
Input: Nhập vào từ bàn phím các thông tin sinh viên như: mã số sinh viên, tên sinh viên, ngành học, điểm trung bình.
Output: Xuất ra thông tin của tất cả sinh viên trên màn hình


BÀI 2: TRÊN CƠ SỞ BÀI 1
Input: nhập số lượng sinh viên muốn thêm từ bàn phím
Output: Xuất ra thông tin của tất cả sinh viên trên màn hình

BÀI 3: SẮP XẾP SINH VIÊN THEO ĐIỂM TĂNG DẦN
Hướng dẫn: Sử dụng lại bài số 1, trước khi hiển thị sinh viên ra màn hình thì chạy giải thuật sắp xếp

BÀI 4: TÌM KIẾM SINH VIÊN
Hướng dẫn: Sau khi đã nhập thông tin sinh viên vào mảng. Tìm kiếm sinh viên theo mã sinh viên

THỰC HIỆN:

BÀI 1: XÂY DỰNG CHƯƠNG TRÌNH LƯU THÔNG TIN SINH VIÊN
Input: Nhập vào từ bàn phím các thông tin sinh viên như: mã số sinh viên, tên sinh viên, ngành học, điểm trung bình.
Output: Xuất ra thông tin của tất cả sinh viên trên màn hình


code tham khảo:
#include<stdio.h>
struct SinhVien{
	char maSinhVien[8];
	char tenSinhVien[50];
	float diemTrungBinh;
};

typedef struct SinhVien SV;

void nhapSinhVienConTro(SV *sv){
	
	printf("\nNhap ma so SV: "); scanf("%s", &sv->maSinhVien);
	
	printf("\nNhap ho ten SV: "); 
	getchar();
	gets(sv->tenSinhVien);
	
	printf("\nNhap diem trung binh: "); scanf("%f", &sv->diemTrungBinh);
}

void xuatSinhVien(SV sv){
	printf ("\n\nThong tin sinh vien:");
	printf ("\nMa so SV: %s", sv.maSinhVien);
	printf ("\nHo ten SV: %s", sv.tenSinhVien);
	printf ("\nDiem trung binh cac mon: %.1f", sv.diemTrungBinh);
}
int main(){
	
	SV sv[100];
	int i;
	int n;
	printf ("\nNhap vao so luong SV muon them: ");
	scanf("%d", &n);
	
	for (i = 0; i < n; i++){
		nhapSinhVienConTro(&sv[i]);
	}
	
	for (i = 0; i < n; i++){
		xuatSinhVien(sv[i]);	
	} 
}   

BÀI 2: TRÊN CƠ SỞ BÀI 1
Input: nhập số lượng sinh viên muốn thêm từ bàn phím
Output: Xuất ra thông tin của tất cả sinh viên trên màn hình

code tham khảo:
#include<stdio.h>
struct SinhVien{
	char maSinhVien[8];
	char tenSinhVien[50];
	float diemTrungBinh;
};

typedef struct SinhVien SV;

void nhapSinhVienConTro(SV *sv){
	
	printf("\nNhap ma so SV: "); scanf("%s", &sv->maSinhVien);
	
	printf("\nNhap ho ten SV: "); 
	getchar();
	gets(sv->tenSinhVien);
	
	printf("\nNhap diem trung binh: "); scanf("%f", &sv->diemTrungBinh);
}

void xuatSinhVien(SV sv){
	printf ("\n\nThong tin sinh vien:");
	printf ("\nMa so SV: %s", sv.maSinhVien);
	printf ("\nHo ten SV: %s", sv.tenSinhVien);
	printf ("\nDiem trung binh cac mon: %.1f", sv.diemTrungBinh);
}
int main(){
	
	SV sv[100];
	int i;
	int n;
	printf ("\nNhap vao so luong SV muon them: ");
	scanf("%d", &n);
	
	for (i = 0; i < n; i++){
		nhapSinhVienConTro(&sv[i]);
	}
	
	for (i = 0; i < n; i++){
		xuatSinhVien(sv[i]);	
	} 
}

BÀI 3: SẮP XẾP SINH VIÊN THEO ĐIỂM TĂNG DẦN
Hướng dẫn: Sử dụng lại bài số 1, trước khi hiển thị sinh viên ra màn hình thì chạy giải thuật sắp xếp

code tham khảo:
#include<stdio.h>
struct SinhVien{
	char maSinhVien[8];
	char tenSinhVien[50];
	float diemTrungBinh;
};

typedef struct SinhVien SV;

void nhapSinhVienConTro(SV *sv){
	
	printf("\nNhap ma so SV: "); scanf("%s", &sv->maSinhVien);
	
	printf("\nNhap ho ten SV: "); 
	getchar();

	gets(sv->tenSinhVien);
	printf("\nNhap diem trung binh: "); scanf("%f", &sv->diemTrungBinh);
}

void xuatSinhVien(SV sv){
	printf ("\n\nThong tin sinh vien:");
	printf ("\nMa so SV: %s", sv.maSinhVien);
	printf ("\nHo ten SV: %s", sv.tenSinhVien);
	printf ("\nDiem trung binh cac mon: %.1f", sv.diemTrungBinh);
}

void sapXep(SV sv[], int n){
	int i, j;
	for (i = 0; i < n - 1; i++){
		for (j = i + 1; j < n; j++){
			if (sv[i].diemTrungBinh > sv[j].diemTrungBinh){
				SV svtmp;
				svtmp = sv[i];
				sv[i] = sv[j];
				sv[j] = svtmp;
			}
		}
	}
}

int main(){
	
	SV sv[100];
	int i;
	int n;
	char maTimKiem[100];
	printf ("\nNhap vao so luong SV muon them: ");
	scanf("%d", &n);
	for (i = 0; i < n; i++){
		nhapSinhVienConTro(&sv[i]);
	}
	
	for (i = 0; i < n; i++){
		xuatSinhVien(sv[i]);	
	} 
	
	sapXep(sv, n);
	for (i = 0; i < n; i++){
		xuatSinhVien(sv[i]);	
	} 

} 

BÀI 4: TÌM KIẾM SINH VIÊN
Hướng dẫn: Sau khi đã nhập thông tin sinh viên vào mảng. Tìm kiếm sinh viên theo mã sinh viên

code tham khảo:
#include<stdio.h>
struct SinhVien{
	char maSinhVien[8];
	char tenSinhVien[50];
	float diemTrungBinh;
};

typedef struct SinhVien SV;

SV nhapSinhVien(){
	SV sv;
	printf("\nNhap ma so SV: "); scanf("%s", &sv.maSinhVien);
	
	printf("\nNhap ho ten SV: "); 
	getchar();

	gets(sv.tenSinhVien);
	printf("\nNhap diem trung binh: "); scanf("%f", &sv.diemTrungBinh);
	return sv;
}

void nhapSinhVienConTro(SV *sv){
	
	printf("\nNhap ma so SV: "); scanf("%s", &sv->maSinhVien);
	
	printf("\nNhap ho ten SV: "); 
	getchar();

	gets(sv->tenSinhVien);
	printf("\nNhap diem trung binh: "); scanf("%f", &sv->diemTrungBinh);
}

void xuatSinhVien(SV sv){
	printf ("\n\nThong tin sinh vien:");
	printf ("\nMa so SV: %s", sv.maSinhVien);
	printf ("\nHo ten SV: %s", sv.tenSinhVien);
	printf ("\nDiem trung binh cac mon: %.1f", sv.diemTrungBinh);
}

void timKiemSinhVien(SV sv[], int n, char maSoSinhVien[100]){
	int i;
	for (i = 0; i < n; i++){
		if (strcmp(maSoSinhVien, sv[i].maSinhVien) == 0){
			xuatSinhVien(sv[i]);
			return;
		}
	}
	printf("\nKhong tim thay sinh vien co ma %s", maSoSinhVien);
	
}
int main(){
	
	SV sv[100];
	int i;
	int n;
	char maTimKiem[100];
	printf ("\nNhap vao so luong SV muon them: ");
	scanf("%d", &n);
	for (i = 0; i < n; i++){
		nhapSinhVienConTro(&sv[i]);
	}
	
	for (i = 0; i < n; i++){
		xuatSinhVien(sv[i]);	
	} 
	
	printf("\nNhap vao ma sinh vien can tim: ");
	scanf("%s", maTimKiem);
	timKiemSinhVien(sv, n, maTimKiem);
}


Xong!

[Tự Học Lập Trình C - Qua Các Bài Tập] COM108_Nhập Môn Lập Trình - Bài 6 - Mảng (Array) Trong C - P1

MỤC TIÊU: Sau bài thực hành, các bạn có khả năng thực hiện được:
  • Biết sử dụng mảng 1 chiều trong lập trình
  • Biết sử dụng mảng 2 chiều trong lập trình
LÝ THUYẾT:


MẢNG 1 CHIỀU

MẢNG LÀ GÌ?
Mảng là tập hợp các phần tử có cùng kiểu dữ liệu
CÁCH KHAI BÁO
Khai báo KHÔNG khởi tạo
int mangMotChieu[5];// khởi tạo mảng 1 chiều có kiểu dữ liệu là số nguyên (int) có có chiều dài là 5
int mangMotChieu_KhaiBaoKhac[]; // khởi tạo mảng có độ dài không cố định, có kiểu dữ liệu là int

Thêm giá trị vào mảng
mangMotChieu[0] = 25;
mangMotChieu[1] = 50;
mangMotChieu[2] = 75;
mangMotChieu[3] = 100;
mangMotChieu[4] = 200;;

Khai báo CÓ khởi tạo
int mangMotChieu[] = {25, 50, 75, 100, 200};

Chúng ta có thể truy cập/thay đổi giá trị của mảng thông qua chỉ số Index
printf("%d", mangMotChieu[2]);

Ví dụ: Truy cập vào vị trí có Index 2 và xuất giá trị ra màn hình
#include<stdio.h>
int main()
{
  int mangMotChieu[] = {25, 50, 75, 100, 200};
  printf("%d", mangMotChieu[2]); // in ra giá trị của mảng tại vị trí có chỉ số Index là 2
  // Kết quả là 75 vì trong C index bắt đầu từ 0
}

Kích thức/Độ dài của mảng
int mangMotChieu[] = {25, 50, 75, 100, 200};
int soPhanTuTrongMang = sizeof mangMotChieu / sizeof (int);
Kiểu dữ liệu int có 4byte trên mỗi phần tử, nên để biết mảng có bao nhiêu phần tử thì chúng ta phải lấy độ dài của mảng chia cho độ dài của kiểu dữ liệu. Ví dụ trên là 20/4 = 5

Ví dụ:
#include<stdio.h>
int main()
{
  int i;
  int mangMotChieu[] = {25, 50, 75, 100, 200};
  int soPhanTuTrongMang = sizeof mangMotChieu / sizeof (int);
printf("\nMang co '%d' phan tu!", soPhanTuTrongMang);
}

Cách duyệt mảng
#include<stdio.h>
int main()
{
  int i;
  int mangMotChieu[] = {25, 50, 75, 100, 200};
  for (i = 0; i < 5; i++)
  {
    printf("%d ", mangMotChieu[i]);
  }
}

Lợi ích của mảng
- Sử dụng mảng để nắm giữ nhiều giá trị thay vì phải khai báo nhiều biến.
- Truy xuất nhanh
- Dễ dàng đọc dữ liệu từ các phần tử và sắp xếp

MẢNG 2 CHIỀU
Chúng ta tạm hiểu mảng 2 chiều một sheet của file excel nó bao gồm các hàng và các cột.
Ví dụ:

Cách khai báo:
Ví dụ: mảng có 2 hàng và 3 cột
int mangHaiChieu[2][3] = { {1, 4, 2}, {3, 6, 8} };

Truy xuất vào mảng 2 chiều
int mangHaiChieu[2][3] = { {1, 4, 2}, {3, 6, 8} };
printf("%d", mangHaiChieu[0][2]); 
/* 
kết quả là 2
truy xuất và lấy giá trị hàng 0 cột 2 
*/

Thay đổi giá trị của mảng 2 chiều
int mangHaiChieu[2][3] = { {1, 4, 2}, {3, 6, 8} };
mangHaiChieu[0][0] = 9; // thay đổi/gán giá trị hàng 0, cột 0 bằng 9

printf("%d", mangHaiChieu[0][0]); // kết quả là 9 thay vì 1 

Cách duyệt mảng 2 chiều: Duyệt mảng 2 chiều cần 2 vòng lặp (1 cho dòng, 1 cho cột)
int mangHaiChieu[2][3] = { {1, 4, 2}, {3, 6, 8} };
int i, j;
for (i = 0; i < 2; i++) {
  for (j = 0; j < 3; j++) {
    printf("%d\n", mangHaiChieu[i][j]);
  }
}
Chú ý khi khai báo mảng chúng ta phải xác định số cột, nếu không sẽ báo lỗi

Hàm nhập mảng 2 chiều
void nhapMangHaiChieu(int hang, int cot, int mangHaiChieu[][100]){
  int i, j;
  for (i = 0 ; i < hang ; i++)
  {
    for (j = 0 ; j < cot ; j++)
    {
      printf("\nNhap vao phan tu HANG %d COT %d cua mang: ", i + 1, j + 1);
      scanf("%d", &mangHaiChieu[i][j]); 
    }
  }
}

Hàm in/xuất mảng 2 chiều
void xuatMangHaiChieu(int hang, int cot, int mangHaiChieu[][100]){
  int i, j;
  printf("\nCac gia tri trong Mang 2 chieu la:\n");
  for (i = 0 ; i < hang ; i++)
  {
    for (j = 0 ; j < cot ; j++)
    {
      printf("%d\t", mangHaiChieu[i][j]); 
    }
    printf("\n");
  }
}

Hàm chính gọi nhập xuất:
#include<stdio.h>
int main()
{ 
  int hang, cot;
  int mangHaiChieu[100][100];
  printf("\n=====MANG 2 CHIEU=====");
  printf("\nNhap vao so HANG: "); scanf("%d", &hang);
  printf("\nNhap vao so COT: "); scanf("%d", &cot);
  nhapMangHaiChieu(hang, cot, mangHaiChieu);
  xuatMangHaiChieu(hang, cot, mangHaiChieu);
  
}


YÊU CẦU:
BÀI 1:
TÍNH TRUNG BÌNH TỔNG CÁC SỐ CHIA HẾT CHO 3 TRONG MẢNG
Input: Nhập vào từ bàn phím 1 mảng các số nguyên. Mảng gồm n phần tử
Output: 
- Xuất ra các phần tử trong mảng
- In ra tổng các phần tử trong mảng
 
BÀI 2:
TÌM GIÁ TRỊ LỚN NHẤT VÀ NHỎ NHẤT TRONG MẢNG
Input: Nhập vào từ bàn phím 1 mảng các số nguyên. Mảng gồm n phần tử
Output: Xuất ra màn hình giá trị nhỏ nhất và lớn nhất của mảng

BÀI 3: 
SẮP XẾP MẢNG THEO THỨ TỪ GIẢM DẦN
Input: Nhập vào từ bàn phím 1 mảng các số nguyên. Mảng gồm n phần tử
Output: Xuất ra màn hình kết quả mảng đã sắp xếp


BÀI 4: 
TÍNH BÌNH PHƯƠNG CÁC PHẦN TỬ TRONG MẢNG 2 CHIỀU
Input: Nhập vào từ bàn phím 1 ma trận các số nguyên. Mảng gồm n hàng, m cột
Output: Xuất ra màn hình ma trận bình phương

THỰC HIỆN:

BÀI 1: 
TÍNH TRUNG BÌNH TỔNG CÁC SỐ CHIA HẾT CHO 3 TRONG MẢNG
Input: Nhập vào từ bàn phím 1 mảng các số nguyên. Mảng gồm n phần tử
Output: 
- Xuất ra các phần tử trong mảng

Code:
#include<stdio.h>
int main()
{	
	int n;
	int mangMotChieu[n];

	printf("\nNhap vao so phan tu MANG MOT CHIEU: ");
	scanf("%d", &n);

	// Nhập/ gán giá trị cho mảng
	int i;
	for (i = 0 ; i < n ; i++){
		printf("\nNhap vao phan tu thu %d cua mang: ", i + 1);
		scanf("%d", &mangMotChieu[i]); // đọc và lưu giá trị vào mảng
	}
	
	// duyệt mảng và int ra màn hình
	for (i = 0 ; i < n ; i++){
		printf("\nGia tri phan tu thu %d MANG MOT CHIEU la: %d ", i + 1, mangMotChieu[i]);
		
	}
}

Khuyến khích viết theo dạng gọi hàm:
- In ra tổng các phần tử trong mảng
code:
#include<stdio.h>

void nhapMangMotChieu(int n, int mangMotChieu[]){
	int i;
	for (i = 0 ; i < n ; i++){
		printf("\nNhap vao phan tu thu %d cua mang: ", i + 1);
		scanf("%d", &mangMotChieu[i]); 
	}
}

void inMangMotChieu(int n, int mangMotChieu[]){
	int i;
	for (i = 0 ; i < n ; i++){
		printf("\nGia tri phan tu thu %d MANG MOT CHIEU la: %d ", i + 1, mangMotChieu[i]);	
	}
}

int tongPhanTuTrongMang(int n, int mangMotChieu[]){
	int i;
	int tong = 0;
	for (i = 0 ; i < n ; i++){
//		tong = tong + mangMotChieu[i];
		tong += mangMotChieu[i];	
	}
	return tong;
}

int main()
{	
	int n;
	int mangMotChieu[n];

	printf("\nNhap vao so phan tu MANG MOT CHIEU: ");
	scanf("%d", &n);
	
	nhapMangMotChieu(n, mangMotChieu);
	inMangMotChieu(n, mangMotChieu);
	printf("\nTong cac phan tu trong mang %d", tongPhanTuTrongMang(n, mangMotChieu));
	
}


- Xuất ra màn hình kết quả của trung bình tổng các số chia hết cho 3 trong mảng
Code:
#include<stdio.h>
int main()
{	
	int n;
	int mangMotChieu[n];

	printf("\nNhap vao so phan tu MANG MOT CHIEU: ");
	scanf("%d", &n);

	// Nhập/ gán giá trị cho mảng
	int i;
	for (i = 0 ; i < n ; i++){
		printf("\nNhap vao phan tu thu %d cua mang: ", i + 1);
		scanf("%d", &mangMotChieu[i]); // đọc và lưu giá trị vào mảng
	}
	
	// duyệt mảng và int ra màn hình
	for (i = 0 ; i < n ; i++){
		printf("\nGia tri phan tu thu %d MANG MOT CHIEU la: %d ", i + 1, mangMotChieu[i]);
		
	}

	// tính trung bình cộng của các số chia hết cho 3
	float trungBinhCong = 0;
	float tong = 0;
	int bienDem;
	for (i = 0 ; i < n ; i++){
		if (mangMotChieu[i] % 3 == 0){
			tong = tong + mangMotChieu[i];
			//  tong += mangMotChieu[i]; // hoặc
			bienDem++;
		}
	}
	trungBinhCong = tong / bienDem;
	printf("\nTrung binh cong cua cac so chia het cho 3 la: %.2f", trungBinhCong);
}

Viết hàm:
int trungBinhCacPhanTuChiaHetCho3(int n, int mangMotChieu[n]){
	int i;
	int tong = 0;
	int dem = 0;
	for(i = 0; i < n ;i++){
		if(mangMotChieu[i] % 3 == 0){
			tong = tong + mangMotChieu[i];
			dem ++;
		}
	}
	return tong/dem;
}


Code đầy đủ:
#include<stdio.h>

void nhapMangMotChieu(int n, int mangMotChieu[n]){
		//nhap vao
	int i;
	for(i = 0; i < n ;i++){
		printf("Nhap vao phan tu thu %d cua mang: ", i + 1);
		scanf("%d", &mangMotChieu[i]);
	}
}

void xuatMangMotChieu(int n, int mangMotChieu[n]){
	int i;
	for(i = 0; i < n ;i++){
		printf("%d\t", mangMotChieu[i]);
	}
}

int tongCacPhanTuTrongMang(int n, int mangMotChieu[n]){
	int i;
	int tong = 0;
	for(i = 0; i < n ;i++){
		tong = tong + mangMotChieu[i];
	}
	return tong;
}

int trungBinhCacPhanTuChiaHetCho3(int n, int mangMotChieu[n]){
	int i;
	int tong = 0;
	int dem = 0;
	for(i = 0; i < n ;i++){
		if(mangMotChieu[i] % 3 == 0){
			tong = tong + mangMotChieu[i];
			dem ++;
		}
	}
	return tong/dem;
}


int main()
{	
 	int n; // chieu dai mang
 	int mangMotChieu[n];
 		
 	printf("\nNhap vao so phan tu Mang MOT chieu: ");
	scanf("%d", &n);
	
	nhapMangMotChieu(n, mangMotChieu);
//	xuatMangMotChieu(n, mangMotChieu);
	printf("%d", trungBinhCacPhanTuChiaHetCho3(n, mangMotChieu));



}

BÀI 2: 
TÌM GIÁ TRỊ LỚN NHẤT VÀ NHỎ NHẤT TRONG MẢNG
Input: Nhập vào từ bàn phím 1 mảng các số nguyên. Mảng gồm n phần tử
Output: Xuất ra màn hình giá trị nhỏ nhất và lớn nhất của mảng

#include<stdio.h>
int main()
{	
	int n;
	int mangMotChieu[n];

	printf("\nNhap vao so phan tu MANG MOT CHIEU: ");
	scanf("%d", &n);

	// Nhập/ gán giá trị cho mảng
	int i;
	for (i = 0 ; i < n ; i++){
		printf("\nNhap vao phan tu thu %d cua mang: ", i + 1);
		scanf("%d", &mangMotChieu[i]); // đọc và lưu giá trị vào mảng
	}
	
	// tìm phần tử LỚN nhất, NHỎ nhất trong mảng
	int min = mangMotChieu[0];
	int max = mangMotChieu[0];
	for ( i = 0; i < n; i++)
	{
		if (mangMotChieu[i] < min){ //NHỎ nhất
			min = mangMotChieu[i];
		}
		if (mangMotChieu[i] > max){ //LỚN nhất
			max = mangMotChieu[i];
		}
	}
	printf("\nPhan tu NHO nhat cua mang la: %d", min);
	printf("\nPhan tu LON nhat cua mang la: %d", max);
}

Viết dạng hàm:
int timPhanTuLonNhat(int n, int mangMotChieu[n]){
	int max = mangMotChieu[0];
	int i;
	for(i = 0; i < n; i++){
		if (mangMotChieu[i] > max) max = mangMotChieu[i];
	}
	return max;
}


int timPhanTuNHONhat(int n, int mangMotChieu[n]){
	int min = mangMotChieu[0];
	int i;
	for(i = 0; i < n; i++){
		if (mangMotChieu[i] < min) min = mangMotChieu[i];
	}
	return min;
}

Code đầy đủ
#include<stdio.h>

void nhapMangMotChieu(int n, int mangMotChieu[n]){
		//nhap vao
	int i;
	for(i = 0; i < n ;i++){
		printf("Nhap vao phan tu thu %d cua mang: ", i + 1);
		scanf("%d", &mangMotChieu[i]);
	}
}

int timPhanTuLonNhat(int n, int mangMotChieu[n]){
	int max = mangMotChieu[0];
	int i;
	for(i = 0; i < n; i++){
		if (mangMotChieu[i] > max) max = mangMotChieu[i];
	}
	return max;
}


int timPhanTuNHONhat(int n, int mangMotChieu[n]){
	int min = mangMotChieu[0];
	int i;
	for(i = 0; i < n; i++){
		if (mangMotChieu[i] < min) min = mangMotChieu[i];
	}
	return min;
}

int main()
{	
 	int n; // chieu dai mang
 	int mangMotChieu[n];
 		
 	printf("\nNhap vao so phan tu Mang MOT chieu: ");
	scanf("%d", &n);
	
	nhapMangMotChieu(n, mangMotChieu);
//	xuatMangMotChieu(n, mangMotChieu);
	printf("\nPhan tu LON nhat cua mang la: %d", timPhanTuLonNhat(n, mangMotChieu));
//	printf("\nPhan tu NHO nhat cua mang la: %d", timPhanTuNHONhat(n, mangMotChieu));

}


Viết kiểu CON TRỎ

BÀI 3: 
SẮP XẾP MẢNG THEO THỨ TỪ GIẢM DẦN
Input: Nhập vào từ bàn phím 1 mảng các số nguyên. Mảng gồm n phần tử
Output: Xuất ra màn hình kết quả mảng đã sắp xếp

lưu file dạng .CPP
void hoanVi(int &a, int &b) 
{
    int temp = a;
    a = b;
    b = temp;
}

void sapXepMang(int n, int mangMotChieu[]){
	int i, j;
	for (i=0; i < n -1; i++){
		for (j=i+1; j < n ; j++){
			if (mangMotChieu[i] > mangMotChieu[j]){ // thay đổi dấu theo yêu cầu tăng hay giảm
				
				hoanVi(mangMotChieu[i], mangMotChieu[j]);
			}
				
		}
	}
}




BÀI 4: 
TÍNH BÌNH PHƯƠNG CÁC PHẦN TỬ TRONG MẢNG 2 CHIỀU
Input: Nhập vào từ bàn phím 1 ma trận các số nguyên. Mảng gồm n hàng, m cột
Output: Xuất ra màn hình ma trận bình phương



Viết Hàm Nhập Xuất

// Nhập mảng hai chiều
void taoMangHaiChieu(int n, int m, int mangHaiChieu[n][m]) {
  int i, j;
  for ( i = 0; i < n; i++) {
    for ( j = 0; j < m; j++) {
      printf("Nhap phan tu mangHaiChieu[%d][%d]: ", i, j);
      scanf("%d", &mangHaiChieu[i][j]);
    }
  }
}

// Xuất mảng hai chiều
void xuatMangHaiChieu(int n, int m, int mangHaiChieu[n][m]) {
  int i, j;
  for ( i = 0; i < n; i++) {
    for ( j = 0; j < m; j++) {
      printf("%d\t", mangHaiChieu[i][j]);
    }
    printf("\n");
  }
}

Viết hàm tính bình phương
// Hàm tính bình phương số nguyên
int binhPhuong(int x) {
  return x * x;
}

void tinhBinhPhuong(int n, int m, int mangHaiChieu[n][m]) {
  int i, j;
  for ( i = 0; i < n; i++) {
    for ( j = 0; j < m; j++) {
//    	mangHaiChieu[i][j] = mangHaiChieu[i][j] * mangHaiChieu[i][j]; // có thể tính trực tiếp
      mangHaiChieu[i][j] = binhPhuong(mangHaiChieu[i][j]); // hoặc có thể gọi hàm tính bình phương
    }
  }
}


Hàm chính
int main() {
  int n, m;
//  printf("Nhập số hàng: ");
//  scanf("%d", &n);
//  printf("Nhập số cột: ");
//  scanf("%d", &m);

  // gắng trực tiếp để test
  n = 2; m =3;
  int mangHaiChieu[n][m];
  khoiTaoMangHaiChieu(n, m, mangHaiChieu);
  tinhBinhPhuong(n, m, mangHaiChieu);
  xuatMangHaiChieu(n, m, mangHaiChieu);
}


Xong!

[Tự Học Lập Trình C - Qua Các Bài Tập] COM108_Nhập Môn Lập Trình - Bài 5 - P1 Xây Dựng Hàm

MỤC TIÊU:
  • Biết cách sử dụng hàm để xây dựng các chức năng
  • Biết cách sử dụng con trỏ và gọi hàm theo tham chiếu
LÝ THUYẾT:

Hàm là gì?
Hàm là khối dòng lệnh mà nó chỉ chạy khi gọi nó. Các hàm thường dùng như: main(), printf(), scanf(), gets(), puts(), ceil(), floor()...

Có 2 loại hàm trong C
- Các hàm thư viện: Là các hàm được khai báo trong tập tin header của chương trình
- Các hàm do người dùng định nghĩa: Là các hàm do lập trình viên định nghĩa.



Cú pháp hàm:



Kiểu dữ liệu trả về có 2 loại:


- Void: Không trả về giá trị nào cả 
Ví dụ:
#include<stdio.h>
void goiHamTrongC()
{
	printf("\nHam chi thuc hien khi no duoc goi") ;	
	printf("\nDay la ham khong tra ve gia tri nao ca") ;
}

int main()
{
	goiHamTrongC(); // gọi hàm
}

- float / int / long / char … : Trả về giá trị kết quả có kiểu dữ liệu tương ứng
Ví dụ:

Tên hàm: Do người dùng tự đặt theo một quy ước
[]: có thể có hoặc không có
[ Danh sách các tham số truyền vào ]: Những tham số này sẽ nhận giá trị thực bằng cách truyền tham số mỗi khi hàm này được gọi đến.

Cách gọi hàm:



Ví dụ:
#include<stdio.h>

int tinhTong (int a, int b)
{
	int tong ;
	tong = a + b ;
	return tong ; // trả về giá trị là tổng của 2 số int
}

int main()
{
	int tong;
	tong = tinhTong(1,2); // gọi hàm tính tổng
	printf("\nTong cua 2 so la: %d", tong) ;
}
Con trỏ:
Con trỏ (Pointer) trong C là một biến, nó còn được gọi là locator hoặc indicator chỉ ra một địa chỉ của một giá trị.

Các ký hiệu sử dụng trong con trỏ:

Ví dụ:
#include<stdio.h>
int main()
{
	int a = 10 ;
	printf("\nGia tri cua a la: %d", a);
	printf("\nDia chi cua bien a la: %x", &a); //& là trả về địa chỉ của một biến, %x hiển thị giá trị của biến
}
Cách khai báo biến con trỏ trong C:
Con trỏ bằng ngôn ngữ C được khai báo bằng cách sử dụng dấu '*'
Ví dụ: int *p;

Ví dụ 1: Viết hàm tính tổng của 2 số, tổng của 2 số là biến con trỏ 
Code tham khảo:
#include<stdio.h>
void tinhTongConTro(int a, int b, int *tongHaiSo){
	*tongHaiSo = a + b; 
}

int main(){
	int a, b;
	a = 10;
	b = 200;
		
	int tong;
	tinhTongConTro(a, b, &tong);
	printf("\nTong 2 so %d + %d = %d", a, b, tong);
}

Ví dụ 2: Nhập vào 2 số tự nhiên a và b, viết hàm trả về 2 giá trị là số lớn và số bé (dùng biến con trỏ để lưu các giá trị trả về của chúng)
Code tham khảo:
#include<stdio.h>
void traVeLonBe(int a, int b, int *soLon, int*soBe){
	if (a > b){
		*soLon = a;
		*soBe = b;
	} else {
		*soLon = b;
		*soBe = a;
	}
}

int main(){
	int a, b;
	a = 1000;
	b = 200;
	
	int i, j;
	traVeLonBe(a, b, &i, &j);
	printf("\nSoLon: %d", i);
	printf("\nSoBe: %d", j);
}


YÊU CẦU:

Bài 1: Xây dựng chương trình tìm số lớn nhất trong 3 số
Input: Nhập từ bàn phím 3 số bất kỳ
Output: Xuất ra màn hình số lớn nhất trong 3 số

Bài 2: Xây dựng chương trình tính năm nhuận
Input: Nhập vào năm
Output: Có phải là năm nhuận hay không?
Biết rằng: Năm nhuận là năm chia hết cho 400 hoặc chia hết cho 4 nhưng không chia hết cho 100


Bài 3: Xây dựng chương trình hoán vị (hoán vị giá trị của 2 số) sử dụng con trỏ và gọi hàm theo tham chiếu
Input: Nhập vào từ bàn phím 2 giá trị a,b
Output: hoán vị 2 giá trị của a và b


Bài 4 (làm thêm): Xây dựng hàm có truyền tham số đầu vào, và trả về kết quả cho các yêu cầu:
- Hàm kiểm tra chẵn lẻ
- Hàm kiểm tra số chính phương
Input: Nhập vào số có kiểu dữ liệu integer từ bàn phím
Output: in ra các số chẵn và là số chính phương trong khoảng từ 1 đến số vừa nhập

Bài 5 (làm thêm): Xây dựng hàm có truyền tham số đầu vào, và trả về kết quả cho các yêu cầu:
- Hàm kiểm tra số nguyên tố
Input: Nhập vào số có kiểu dữ liệu integer từ bàn phím
Output: in ra các số nguyên tố trong khoảng từ 1 đến số vừa nhập

Bài 6 (làm thêm): Xây dựng hàm với 2 tham số đầu vào a, b; kiểm tra a có chia hết cho b hay không và trả về kết quả kiểm tra, giá trị trả về có thể là kiểu int, bool, char,..
Input: Nhập 2 số có kiểu dữ liệu integer a, b từ bàn phím
Output: in ra kết quả có chia hết hay không

THỰC HIỆN

Bài 1: Xây dựng chương trình tìm số lớn nhất trong 3 số
Input: Nhập từ bàn phím 3 số bất kỳ
Output: Xuất ra màn hình số lớn nhất trong 3 số

Code:
/*
Xây dựng chương trình tìm số lớn nhất trong 3 số
Input: Nhập từ bàn phím 3 số bất kỳ
Output: Xuất ra màn hình số lớn nhất trong 3 số
*/
#include<stdio.h>

int timSoLonNhat(int a, int b, int c){
    int MaxTemp;
    MaxTemp = a;
    if (b > MaxTemp)
    {
        MaxTemp = b;
    }
    if (c > MaxTemp)
    {
        MaxTemp = c;
    }
    return MaxTemp;
}

int main()
{
    int a, b, c;
    int soLonNhat;
    
    // soLonNhat = timSoLonNhat(5, 50, 12); // có thể truyền số trực tiếp
    printf("Nhap vao so a b c: "); 
    scanf("%d%d%d", &a, &b, &c); // có thể đọc 3 số một lần, mỗi số nhập vào cách nhau MỘT KHOẢNG TRẮNG

    soLonNhat = timSoLonNhat(a, b, c);
    printf("%d la so lon nhat!", soLonNhat);
}

Các hàm tìm max 2 số tham khảo khác:
int timMax(int a, int b){
	if (a > b) return a;
	return b;
}

int timSoLonNhat(int a, int b){
	return (a >= b) ? a : b;
}


Bài 2: Xây dựng chương trình tính năm nhuận
Input: Nhập vào năm
Output: Có phải là năm nhuận hay không?
Biết rằng: Năm nhuận là năm chia hết cho 400 hoặc chia hết cho 4 nhưng không chia hết cho 100


Những năm nhuận của thế kỷ 21 là:
    2004, 2008, 2012, 2016, 2020, 2024, 2028, 2032,
    2036, 2040, 2044, 2048, 2052, 2056, 2060, 2064,
    2068, 2072, 2076, 2080, 2084, 2088, 2092, 2096.

Code:
/*
Xây dựng chương trình tính năm nhuận
Input: Nhập vào năm
Output: Có phải là năm nhuận hay không?
Biết rằng: Năm nhuận là năm chia hết cho 400 hoặc chia hết cho 4 nhưng không chia hết cho 100

Những năm nhuận của thế kỷ 21 là: 
    2004, 2008, 2012, 2016, 2020, 2024, 2028, 2032, 
    2036, 2040, 2044, 2048, 2052, 2056, 2060, 2064, 
    2068, 2072, 2076, 2080, 2084, 2088, 2092, 2096.

*/
#include<stdio.h>

int tinhNamNhuan(int nam)
{ 
    if ((nam % 400 == 0) || ((nam % 4 == 0) && (nam % 100 != 0)))
    {
        return 1;
    }
    else return 0;
     
}

int main()
{
    int nam;
    printf("Nhap vao nam can kiem tra: ");
    scanf("%d", &nam);
    if (tinhNamNhuan(nam) == 1)
    {
        printf("%d la NAM NHUAN!", nam);
    }
    else printf ("%d KHONG PHAI nam nhuan!", nam);
    
}

Bài 3: Xây dựng chương trình hoán vị (hoán vị giá trị của 2 số) sử dụng con trỏ và gọi hàm theo tham chiếu
Input: Nhập vào từ bàn phím 2 giá trị a,b
Output: hoán vị 2 giá trị của a và b

Code:
/*
Xây dựng chương trình hoán vị (hoán vị giá trị của 2 số) sử dụng con trỏ và gọi hàm theo tham chiếu
Input: Nhập vào từ bàn phím 2 giá trị a,b
Output: hoán vị 2 giá trị của a và b
*/
#include<stdio.h>

// hóa vị thông thường
void hoanVi(int a, int b) 
{
    int temp = a;
    a = b;
    b = temp;
}

// hoán vị dùng con trỏ
void hoanViTro(int *a, int *b)
{
    int temp = *a;
    *a = *b;
    *b = temp;
}

int main()
{
    int a, b;
    printf("Nhap vao so a b: "); 
    scanf("%d%d", &a, &b);
    
    printf("\n===========================\n");
    printf("Hai so vua nhap la: %d & %d\n", a, b);

    // hoanVi(a, b);
    hoanViTro(&a, &b); // gọi hàm nếu hàm có sử dụng con trỏ chúng ta thêm dấu và vào trước các biến
    printf("Hai so sau khi thuc hien HOAN VI: %d & %d\n", a, b);
}

Chú ý:
Khi chúng ta dùng hàm hoanVi(a, b) sẽ cho kết quả là sai (không hoán đổi) tại sao?
Khi ta gọi  thì giá trị của a và b được đưa vào hàm chứ không phải là các biến a, b nên biến a, b của chúng ta không hề thay đổi.

Khuyến khích dùng con trỏ khi viết hàm hoán vị hoặc thêm chữ và (&) trước mỗi biến sau đó lưu thành file .CPP



code:
void hoanVi(int &a, int &b) 
{
    int temp = a;
    a = b;
    b = temp;
}

Bài 4 (làm thêm): Xây dựng hàm có truyền tham số đầu vào, và trả về kết quả cho các yêu cầu:
- Hàm kiểm tra chẵn lẻ
- Hàm kiểm tra số chính phương
Input: Nhập vào số có kiểu dữ liệu integer từ bàn phím
Output: in ra các số chẵn và là số chính phương trong khoảng từ 1 đến số vừa nhập

- Hàm kiểm tra chẵn lẻ:
int kiemTraChanLe(int n){
	int kiemTra;
	
	if (n % 2 == 0){
		kiemTra = 1;
	}else{
		kiemTra = 0;
	}
	
	return kiemTra;
}

- Hàm kiểm tra chẵn lẻ viết cách khác gọn hơn:
int chanLeRutGon(int n){
	if (n % 2 ==0) return 1;
	else return 0;
}

- Hàm kiểm tra số chính phương:
int kiemTraChinhPhuong(int n){
	int kiemTra = 0;
	int canBacHai = sqrt(n); // #include<math.h>
    
	if(canBacHai * canBacHai == n){
    	kiemTra = 1;
    }else{
    	kiemTra = 0;
	}
    return kiemTra;
}

- Chương trình chính:
#include<stdio.h>
int main(){
    int i, n;
   
    printf("\nNhap vao so: ");scanf("%d", &n);

	for (i = 1; i < n; i++){
		if (kiemTraChanLe(i) ==1 && kiemTraChinhPhuong(i) == 1){
			printf(" %d ", i);
		}
	}

}

- Full code chương trình:
#include<stdio.h>
#include<math.h>

int kiemTraChinhPhuong(int n){
	int kiemTra;
	int canBacHai = sqrt(n); // #include<math.h>
    
	if(canBacHai * canBacHai == n){
    	kiemTra = 1;
    }else{
    	kiemTra = 0;
	}
    return kiemTra;
}

int kiemTraChanLe(int n){
	int kiemTra;
	
	if (n % 2 == 0){
		kiemTra = 1;
	}else{
		kiemTra = 0;
	}
	
	return kiemTra;
}

int chanLeRutGon(int n){
	if (n % 2 ==0) return 1;
	else return 0;
}

int main(){
    int i, n;
   
    printf("\nNhap vao so: ");
    scanf("%d", &n);

	for (i = 1; i < n; i++){
		if (kiemTraChanLe(i) ==1 && kiemTraChinhPhuong(i) == 1){
			printf(" %d ", i);
		}
	}

}

Bài 5 (làm thêm): Xây dựng hàm có truyền tham số đầu vào, và trả về kết quả cho các yêu cầu:
- Hàm kiểm tra số nguyên tố
Input: Nhập vào số có kiểu dữ liệu integer từ bàn phím
Output: in ra các số nguyên tố trong khoảng từ 1 đến số vừa nhập

Code gợi ý:
Kiểm tra nguyên tố:
int kiemTraNguyenTo(int x){
	int i;
	int kiemTra = 1;
	for (i = 2; i < x; i++){
        if (x % i == 0) {
        	kiemTra = 0;
            return kiemTra;
        }
    }
	return kiemTra;
} 

int kiemTraNguyenTo1(int x){
	int i;
	for (i = 2; i < x; i++){
        if (x % i == 0) {
            return 0;
        }
    }
	return 1;
} 

int kiemTraNguyenTo2(int x){
	int i;
	for (i = 2; i <= sqrt(x); i++){ // thu vien math.h
        if (x % i == 0) {
            return 0;
        }
    }
	return 1;
}

Hàm  chính:
int main() {
	int x = 100;//????
	for (int i = 2; i <= x; i++){
		if(kiemTraNguyenTo(i) == 1) {
			printf("%d ", i);		
		}
	}
}


Bài 6 (làm thêm): Xây dựng hàm với 2 tham số đầu vào a, b; kiểm tra a có chia hết cho b hay không và trả về kết quả kiểm tra, giá trị kiểm tra có thể là kiểu int, bool, char,.. 
Input: Nhập 2 số có kiểu dữ liệu integer a, b từ bàn phím
Output: in ra kết quả có chia hết hay không
#include<stdio.h>
int kiemTraChiaHet(int a, int b){
	if (a % b == 0) return 1;
	return 0;
}
bool kiemTraChiaHet_bool(int a, int b){ // bool
	if (a % b == 0) return true;
	return false;
}

int main()
{	
	int a, b;
	printf("\nNhap vao 2 so a, b: "); scanf("%d%d", &a, &b); 
	if (kiemTraChiaHet_bool(a, b)){
		printf("\n%d CHIA HET cho %d", a, b);
	}else printf("\n%d KHONG chia het cho %d", a, b);
}

Xong!

[Tự Học Lập Trình C - Qua Các Bài Tập] COM108_Nhập Môn Lập Trình - Bài 4 - WHILE DO-WHILE

MỤC TIÊU:
- Biết cách sử dụng vòng lặp while
- Biết cách sử dụng vòng lặp do while

LÝ THUYẾT:
while


Ví dụ:
/*
int ra màn hình 10 chữ Hello
*/
#include<stdio.h>
int main()
{
	int i;
	i = 0;
	while (i < 10) { //khi i < 10
		printf("\nHello %d", i); // xuất ra dòng chữ Hello
		i++;  // tăng i lên 1 đơn vị
	}
}

for 

Ví dụ:
/*
int ra màn hình 10 chữ Hello
*/
#include<stdio.h>
int main()
{
	int i;
	for (i = 0 ; i < 10 ; i++) { // tương tự như while, biến khởi tạo, điều kiện, bước nhảy nằm trên 1 dòng lệnh
		printf("\nHello %d", i);
	}
}


Cách chuyển đổi while sang for


do - while


Ví dụ:
#include<stdio.h>
int main()
{
	int a;
	a = 6;
 	do {
 		printf("\nHello %d", a);
 		a++;
	} while (a < 3); // điều kiện là a = 3, tuy nhiên chương trình vẫn in dữ liệu ra ngay cả a = 6
}

Khác nhau while và do while



break - continue  

Break: Câu lệnh break được sử dụng để thoát/nhảy ra khỏi vòng lặp (nếu có nhiều vòng lặp lồng nhau thì nó chỉ thoát ra vòng lặp gần nó nhất)

Ví dụ:
/*
int ra màn hình 10 chữ Hello
tuy nhiên gặp break nó phải thoát ra khỏi vòng lặp
Kết quả:
Hello 0
Hello 1
Hello 2
Hello 3
*/
#include<stdio.h>
int main()
{
	int i;
	for (i = 0 ; i < 10 ; i++) { 
		if (i == 4) // nếu i = 4 thì
			break; // thoát ra khỏi vòng lặp gần nó nhất
		printf("\nHello %d", i);
	}
}


Continue: Câu lệnh continue lệnh ngắt/bỏ qua một lần lặp và không thực hiện khối lệnh phía sau nó (trong vòng lặp), nếu một điều kiện cụ thể xảy ra và tiếp tục với lần lặp tiếp theo trong vòng lặp.

Ví dụ:
/*
int ra màn hình 10 chữ Hello
tuy nhiên gặp continue nó bỏ qua không thực hiện lệnh sau đó mà quay lại vòng lặp
Kết quả:
Hello 0
Hello 1
Hello 2
Hello 3
Hello 5
Hello 6
Hello 7
Hello 8
Hello 9
*/
#include<stdio.h>
int main()
{
	int i;
	for (i = 0 ; i < 10 ; i++) { 
		if (i == 4) // nếu i = 4 thì
			continue; // không in dòng Hello mà quay lại vòng lặp
		printf("\nHello %d", i);
	}
}


goto

goto: Câu lệnh goto cung cấp một bước nhảy vô điều kiện đến một câu lệnh có nhãn trong cùng một hàm

Noted: goto có nhiều hạn chế nên nó rất ít được sử dụng (chỉ dùng trong 1 vài trường hợp đặc biệt) trong nhiều ngôn ngữ.



YÊU CẦU:
Bài 1:  Tính trung bình tổng các số tự nhiên chia hết cho 2
Input: nhập từ bàn phím 2 giá trị min, max
Output: Trung bình tổng của các số tự nhiên chia hết cho 2 từ min tới max

 
Bài 2: Xác định số nhập vào có phải là số nguyên tố hay không
Input: Nhập vào từ bàn phím số x
Output: Kết luận x có phải là số nguyên tố hay không
Biết rằng: Số nguyên tố là số chỉ chia hết cho 1 và chính nó.

Bài 3: Xây dựng chương trình xây dựng số chính phương
Input: Nhập vào từ bàn phím số x
Output: Kết luận x có phải là số chính phƣơng hay không?
Biết rằng: Số chính phƣơng là một số mà giá trị của nó là bình phƣơng của một số tự nhiên. (ví dụ: 9 = 3 x 3; 16 = 4 x 4; 25 = 5 x 5; 1,000,000 = 1,000 x 1,000)

Bài 4: Xây dựng menu cho 3 bài tập trên
Yêu cầu:
- Nếu người dùng nhập từ bàn phím số 1: -> Chạy chương trình bài 1
- Nếu người dùng nhập từ bàn phím số 2: -> Chạy chƣơng trình bài 2
- Nếu người dùng nhập từ bàn phím số 3: -> Chạy chƣơng trình bài 3
- Nếu người dùng nhập từ bàn phím số 4: -> Thoát khỏi chương trình
- Nếu người dùng nhập từ bàn phím số khác: Hiển thị menu như cũ

Gợi ý: Sử dụng vòng lặp do while kết hợp với cách tạo menu thông thường để làm bài tập số 4


THỰC HIỆN:

Bài 1:  Tính trung bình tổng các số tự nhiên chia hết cho 2
Input: nhập từ bàn phím 2 giá trị min, max
Output: Trung bình tổng của các số tự nhiên chia hết cho 2 từ min tới max

code:
/*
Bài 1:  Tính trung bình tổng các số tự nhiên chia hết cho 2
Input: nhập từ bàn phím 2 giá trị min, max
Output: Trung bình tổng của các số tự nhiên chia hết cho 2 từ min tới max
*/
#include<stdio.h>
int main()
{
    int min, max;
    int tong = 0,  trungBinhTong = 0;
    int bienDem = 0;

    printf("Nhap vao so min: ");
    scanf("%d", &min);
    printf("Nhap vao so max: ");
    scanf("%d", &max);

	int i = min;

    while (i <= max)
    {
        if (i % 2 == 0) // chia lấy dư
        {
            tong = tong + i; // tong +=i
            bienDem ++; // tăng biến đếm lên 1
        }
        i ++; // tăng i lên 1, đây là điều kiện dừng nếu không tăng thì chương trình lặp vô hạn
    }
    trungBinhTong = tong/bienDem;
    printf("\n============================\n");
    printf("Trung binh tong so chia het cho 2 la: %d", trungBinhTong);
}

 

Bài 2: Xác định số nhập vào có phải là số nguyên tố hay không
Input: Nhập vào từ bàn phím số x
Output: Kết luận x có phải là số nguyên tố hay không
Biết rằng: Số nguyên tố là số chỉ chia hết cho 1 và chính nó.

code:
/*
Kiểm tra nguyên tố
Input: Nhập vào từ bàn phím số x
Output: Kết luận x có phải là số nguyên tố hay không
Biết rằng: Số nguyên tố là số chỉ chia hết cho 1 và chính nó (phải đảm bảo 2 điều kiện).


*/
#include<stdio.h>
int main(){
    int x;
    int bienDem = 0;
    // bool kiemTra = true; // giả thiết số nhập vào là số nguyên tố
    printf("Nhap vao so can kiem tra X: ");
    scanf("%d", &x);

    for (int i = 2; i < x; i++){
        if (x % i == 0)
        {
            bienDem ++; // mục đích là đánh dấu số chia hết i 
            // kiemTra = false;
            break; // nếu chia hết cho bất kỳ số nào trong khoảng từ i đến x là có thể khẳng định KHÔNG phải là số nguyên tố
         }
    }
    if (bienDem == 0)
   // if (kiemTra == true)
    {
        printf("%d la so NGUYEN TO!", x);
    } 
    else {
        printf("%d KHONG PHAI so nguyen to!", x);
    }

}
 

Bài 3: Xây dựng chương trình xây dựng số chính phương
Input: Nhập vào từ bàn phím số x
Output: Kết luận x có phải là số chính phương hay không?
Biết rằng: Số chính phương là một số mà giá trị của nó là bình phương của một số tự nhiên. (ví dụ: 9 = 3 x 3; 16 = 4 x 4; 25 = 5 x 5; 1,000,000 = 1,000 x 1,000)

code:
/*
Kiểm tra số chính phương
Input: Nhập vào từ bàn phím số x
Output: Kết luận x có phải là số chính phƣơng hay không?
Biết rằng: Số chính phƣơng là một số mà giá trị của nó là bình phƣơng của một số
tự nhiên. (ví dụ: 9 = 3 x 3; 16 = 4 x 4; 25 = 5 x 5; 1,000,000 = 1,000 x 1,000)
*/

#include<stdio.h>
int main(){
    int x;
    
    printf("Nhap vao so can kiem tra X: ");
    scanf("%d", &x);

    int i;
    int bienDem = 0;
    // char kiemTra = 'k'; // đánh dấu biến kiểm tra 'k' 
    for ( i = 1; i < x; i++)
    {
        if (i * i == x)
        {
            bienDem = 1;
            // kiemTra = 'c'; // đánh dấu = 'c' là số chính phương
            break;
        }
    }
    if (bienDem == 1)
    // if (kiemTra == 'c')
    {
        printf("%d la so CHINH PHUONG!", x);
    }
    else
    {
        printf("%d KHONG PHAI so chinh phuong!", x);
    }   
}

Tham khảo thêm kiểm tra số chính phương KHÔNG DÙNG VÒNG LẶP:
#include<stdio.h>
#include<math.h>

int main(){
    int n;
    int kiemTra = 0;
    printf("\nNhap so can kiem tra: ");scanf("%d", &n);
//    n = 9;
	int canBacHai = sqrt(n);
    
	if(canBacHai * canBacHai == n){
    	kiemTra = 1;
    }
       
    if(kiemTra == 1){
        printf("%d la SO CHINH PHUONG!\n", n);
    }else{
        printf("%d KHONG PHAI so chinh phuong!\n", n);
    }
}
 

Bài 4: Xây dựng menu cho 3 bài tập trên
Yêu cầu:
- Nếu người dùng nhập từ bàn phím số 1: -> Chạy chương trình bài 1
- Nếu người dùng nhập từ bàn phím số 2: -> Chạy chƣơng trình bài 2
- Nếu người dùng nhập từ bàn phím số 3: -> Chạy chƣơng trình bài 3
- Nếu người dùng nhập từ bàn phím số 4: -> Thoát khỏi chương trình
- Nếu người dùng nhập từ bàn phím số khác: Hiển thị menu như cũ

Gợi ý: Sử dụng vòng lặp do while kết hợp với cách tạo menu thông thường để làm bài tập số 4

code:
/*Xây dựng menu cho 3 bài trên
Yêu cầu:
-Nếu ngƣời dùng nhập từ bàn phím số 1: -> Chạy chƣơng trình bài 1
-Nếu ngƣời dùng nhập từ bàn phím số 2: -> Chạy chƣơng trình bài 2
-Nếu ngƣời dùng nhập từ bàn phím số 3: -> Chạy chƣơng trình bài 3
-Nếu ngƣời dùng nhập từ bàn phím số 4: -> Thoát khỏi chƣơng trình
-Nếu ngƣời dùng nhập từ bàn phím số khác: Hiển thị menu nhƣ cũ
*/
#include<stdio.h>

// trung bình tổng chẳn
int bai_01()
{
    int min, max;
    int tong = 0,  trungBinhTong = 0;
    int bienDem = 0;

    printf("Nhap vao so min: ");
    scanf("%d", &min);
    printf("Nhap vao so max: ");
    scanf("%d", &max);

	int i = min;

    while (i <= max)
    {
        if (i % 2 == 0) // chia lấy dư
        {
            tong = tong + i; // tong +=i
            bienDem ++; // tăng biến đếm lên 1
        }
        i ++; // tăng i lên 1, đây là điều kiện dừng nếu không tăng thì chương trình lặp vô hạn
    }
    trungBinhTong = tong/bienDem;
    printf("\n============================\n");
    printf("Trung binh tong so chia het cho 2 la: %d", trungBinhTong);
}

// kiểm tra nguyên tố
int bai_02(){
    int x;
    int bienDem = 0;
    printf("Nhap vao so can kiem tra X: ");
    scanf("%d", &x);

    for (int i = 2; i < x; i++){
        if (x % i == 0)
        {
            bienDem ++; // mục đích là đánh dấu số chia hết i
            break;
        }
    }
    if (bienDem == 0)
    {
        printf("%d la so NGUYEN TO!", x);
    } 
    else {
        printf("%d KHONG PHAI so nguyen to!", x);
    }

}

// kiểm tra số chính phương
int bai_03(){
    int x;
    
    printf("Nhap vao so can kiem tra X: ");
    scanf("%d", &x);

    int i;
    int bienDem = 0;
    for ( i = 1; i < x; i++)
    {
        if (i * i == x)
        {
            bienDem = 1;
            break;
        }
    }
    if (bienDem == 1)
    {
        printf("%d la so CHINH PHUONG!", x);
    }
    else
    {
        printf("%d KHONG PHAI so chinh phuong!", x);
    }   
}

// hàm chính
int main()
{
    int luaChon;
    do
    {
        printf("\n=========== MENU LUA CHON =========\n");
        printf("1. Trung Binh Tong\n");
        printf("2. Kiem Tra Nguyen To\n");
        printf("3. Kiem Tra Chinh Phuong\n");
        printf("0. THOAT CHUONG TRINH!\n");
        printf("\n");
        printf("Lua chon cua ban la: ");
        scanf("%d", &luaChon);
        printf("==================================\n");
        switch (luaChon)
        {
        case 1:
            bai_01(); // gọi hàm bai_1 phía trên hàm main()
            break;
        case 2:
            bai_02();
            break;
        case 3:
            bai_03();
            break;
        case 0: 
            break;
        default:
            printf("Lua chon KHONG DUNG!\n");
            break;
        }
    } while (luaChon != 0);
    
}   
    

Xong!
/*header slide*/