/*
_______________________________________
| Thành Viên Nhóm | Ma Sinh Viên |
|_____________________________________|
| Nguy?n Ð?c Quang | :2411061767 |
| |
| Tr?n Minh Quang | :2411062029 |
| |
| Lu?ng Vi?t Nh?t | :2411061614 |
| |
| Hoàng Gia Th? | :2411061927 |
| |
| Nguy?n Ti?n Dung | :2411061649 |
|_____________________________________|
*/
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#define MAX 100
typedef int Position;
// Cau truc sinh vien
typedef struct {
char tenMon[ 50 ] ;
} MonHoc;
struct Sinhvien {
char id[ 20 ] ;
char name[ 50 ] ;
char ns[ 20 ] ;
int tuoi;
float diem[ MAX] ;
int soMon;
} ;
// Kieu danh sach mang
typedef struct {
struct Sinhvien A[ MAX] ;
int Last;
} List;
// =============================== Cac thao tac co ban ===============================
Position FIRST( List L) {
return 1 ;
}
Position END( List L) {
return L.Last + 1 ;
}
Position NEXT( Position P, List L) {
if ( P < END( L) ) return P + 1 ;
return END( L) ;
}
Position PREVIOUS( Position P, List L) {
if ( P > FIRST( L) ) return P - 1 ;
return FIRST( L) ;
}
struct Sinhvien RETRIEVE( Position P, List L) {
return L.A [ P- 1 ] ;
}
Position LOCATE( char id[ ] , List L) {
for ( int i = 0 ; i < L.Last ; i++ ) {
if ( strcmp ( L.
A [ i
] .
id , id
) == 0 ) return i+ 1 ;
}
return END( L) ;
}
void MAKENULL_LIST( List * L) {
L-> Last = 0 ;
}
int EMPTY_LIST( List L) {
return L.Last == 0 ;
}
void INSERT_LIST( struct Sinhvien x, Position P, List * L) {
if ( L-> Last >= MAX) {
return ;
}
if ( P < FIRST( * L) || P > END( * L) ) {
printf ( "Vi tri khong hop le\n " ) ; return ;
}
for ( int i = L-> Last; i >= P; i-- ) {
L-> A[ i] = L-> A[ i- 1 ] ;
}
L-> A[ P- 1 ] = x;
L-> Last++;
}
void DELETE_LIST( Position P, List * L) {
if ( P < FIRST( * L) || P >= END( * L) ) {
printf ( "Vi tri khong hop le\n " ) ; return ;
}
for ( int i = P- 1 ; i < L-> Last- 1 ; i++ ) {
L-> A[ i] = L-> A[ i+ 1 ] ;
}
L-> Last--;
}
// Xoa sinh vien theo MSV
void DELETE_BY_ID( char id[ ] , List * L) {
printf ( "\n +==========================================================================+\n " ) ; printf ( "| XOA SINH VIEN THEO MSV |\n " ) ; printf ( "+==========================================================================+\n " ) ;
Position p = LOCATE( id, * L) ;
if ( p == END( * L) ) {
printf ( "| Khong tim thay sinh vien co MSV: %-36s|\n " , id
) ; printf ( "+==========================================================================+\n " ) ; return ;
}
struct Sinhvien sv = L-> A[ p - 1 ] ;
char confirm;
printf ( "| Tim thay sinh vien: |\n " ) ; printf ( "| MSSV : %-59s|\n " , sv.
id ) ; printf ( "| Ho ten : %-59s|\n " , sv.
name ) ; printf ( "| Ngay sinh : %-27sTuoi : %-11d |\n " , sv.
ns , sv.
tuoi ) ; printf ( "+--------------------------------------------------------------------------+\n " ) ; printf ( " Ban co chac chan muon xoa sinh vien nay khong? (y/n): " ) ; printf ( "+==========================================================================+\n " ) ;
if ( confirm != 'y' && confirm != 'Y' ) {
printf ( "| Da huy thao tac xoa sinh vien. |\n " ) ; printf ( "+==========================================================================+\n " ) ; return ;
}
for ( int i = p - 1 ; i < L-> Last - 1 ; i++ ) {
L-> A[ i] = L-> A[ i + 1 ] ;
}
L-> Last--;
printf ( "| Da xoa sinh vien thanh cong |\n " ) ; printf ( "+--------------------------------------------------------------------------+\n " ) ; printf ( "| Thong tin sinh vien da xoa: |\n " ) ; printf ( "| MSSV : %-59s|\n " , sv.
id ) ; printf ( "| Ho ten : %-59s|\n " , sv.
name ) ; printf ( "| Ngay sinh : %-27sTuoi : %-11d |\n " , sv.
ns , sv.
tuoi ) ; printf ( "+==========================================================================+\n " ) ; }
// ================== Cac chuc nang mo rong ==================
void ChuanHoan( char s[ ] , int size) {
for ( int i = 0 ; i < size; i++ ) {
if ( s[ i] == '/' ) {
if ( i == 1 ) {
for ( int j = size; j >= 0 ; j-- ) {
s[ j+ 1 ] = s[ j] ;
}
s[ 0 ] = '0' ;
size++;
}
if ( s[ i+ 2 ] == '/' && i+ 2 < size) {
for ( int k = size; k >= i+ 1 ; k-- ) {
s[ k+ 1 ] = s[ k] ;
}
s[ i+ 1 ] = '0' ;
size++;
}
}
}
}
int laNamNhuan( int y) {
return ( ( y % 400 == 0 ) || ( y % 4 == 0 && y % 100 != 0 ) ) ;
}
int soNgayTrongThang( int m, int y) {
if ( m == 1 || m == 3 || m == 5 || m == 7 || m == 8 || m == 10 || m == 12 )
return 31 ;
if ( m == 4 || m == 6 || m == 9 || m == 11 )
return 30 ;
if ( m == 2 )
return laNamNhuan( y) ? 29 : 28 ;
return 0 ;
}
void ChuanHoaTen( char * name) {
char temp[ 100 ] ;
int i = 0 , j = 0 ;
while ( i < len && name[ i] == ' ' ) i++;
int space = 0 ;
while ( i < len) {
if ( name[ i] != ' ' ) {
if ( space && j > 0 ) {
temp[ j++ ] = ' ' ;
space = 0 ;
}
temp[ j++ ] = name[ i] ;
} else {
space = 1 ;
}
i++;
}
if ( j > 0 && temp[ j- 1 ] == ' ' ) j--;
temp[ j] = '\0 ' ;
for ( i = 0 ; i < j; i++ ) {
if ( temp[ i] >= 'A' && temp[ i] <= 'Z' )
temp[ i] = temp[ i] - 'A' + 'a' ;
}
int newWord = 1 ;
for ( i = 0 ; i < j; i++ ) {
if ( temp[ i] == ' ' ) {
newWord = 1 ;
} else if ( newWord && temp[ i] >= 'a' && temp[ i] <= 'z' ) {
temp[ i] = temp[ i] - 'a' + 'A' ;
newWord = 0 ;
} else {
newWord = 0 ;
}
}
}
struct Sinhvien nhapSinhVien( List L) {
struct Sinhvien sv;
printf ( "\n +-----------------------------------------+\n " ) ; printf ( "| NHAP THONG TIN SINH VIEN MOI |\n " ) ; printf ( "+-----------------------------------------+\n " ) ; while ( 1 ) {
if ( LOCATE( sv.id , L) != END( L) ) {
printf ( "MSSV da ton tai, nhap lai\n " ) ; } else {
break ;
}
}
int check;
do {
check = 1 ;
scanf ( " %19[^\n ]" , sv.
name ) ;
for ( int i
= 0 ; i
< strlen ( sv.
name ) ; i
++ ) { if ( ! ( ( sv.name [ i] >= 'a' && sv.name [ i] <= 'z' ) || ( sv.name [ i] >= 'A' && sv.name [ i] <= 'Z' ) || sv.name [ i] == ' ' ) ) {
check = 0 ;
break ;
}
}
if ( check == 0 ) {
printf ( "Ho va ten khong chua so hoac ky tu dac biet (Nhap lai)\n " ) ; } else {
ChuanHoaTen( sv.name ) ;
}
} while ( check == 0 ) ;
do {
printf ( ">> Nhap ngay sinh (dd/mm/yyyy): " ) ;
ChuanHoan( sv.ns , size) ;
char day[ 3 ] , month[ 3 ] , year[ 5 ] ;
day[ 0 ] = sv.ns [ 0 ] ;
day[ 1 ] = sv.ns [ 1 ] ;
day[ 2 ] = '\0 ' ;
month[ 0 ] = sv.ns [ 3 ] ;
month[ 1 ] = sv.ns [ 4 ] ;
month[ 2 ] = '\0 ' ;
for ( int i = 6 , j = 0 ; i <= size; i++, j++ ) {
year[ j] = sv.ns [ i] ;
year[ j+ 1 ] = '\0 ' ;
}
int maxday = soNgayTrongThang( m, y) ;
if ( d <= 0 || d > maxday || m <= 0 || m > 12 || y <= 100 ) {
printf ( "Ngay sinh khong hop le vui long nhap lai!\n " ) ; } else {
int namNow = 2025 ;
do {
if ( sv.tuoi < namNow - y - 2 || sv.tuoi > namNow - y + 2 ) {
printf ( "Vui long nhap lai tuoi dung voi tuoi that cua ban\n " ) ; }
} while ( sv.tuoi < namNow - y - 2 || sv.tuoi > namNow - y + 2 ) ;
break ;
}
} while ( 1 ) ;
return sv;
}
void PRINT_LIST( List L) {
if ( L.Last == 0 ) {
return ;
}
printf ( "\n +-----+--------------+---------------------------+--------------+-------+\n " ) ; printf ( "| STT | MSSV | Ho Ten | Ngay Sinh | Tuoi |\n " ) ; printf ( "+-----+--------------+---------------------------+--------------+-------+\n " ) ;
for ( int i = 0 ; i < L.Last ; i++ ) {
printf ( "| %-3d | %-12s | %-25s | %-12s | %-5d |\n " , i+ 1 , L.A [ i] .id , L.A [ i] .name , L.A [ i] .ns , L.A [ i] .tuoi ) ;
}
printf ( "+-----+--------------+---------------------------+--------------+-------+\n " ) ; }
void SORT_BY_NAME( List * L) {
for ( int i = 0 ; i < L-> Last - 1 ; i++ ) {
for ( int j = i + 1 ; j < L-> Last; j++ ) {
if ( strcmp ( L
-> A
[ i
] .
name , L
-> A
[ j
] .
name ) > 0 ) { struct Sinhvien tmp = L-> A[ i] ;
L-> A[ i] = L-> A[ j] ;
L-> A[ j] = tmp;
}
}
}
printf ( "Da sap xep theo ten\n " ) ; }
void SORT_BY_TUOI( List * L) {
for ( int i = 0 ; i < L-> Last - 1 ; i++ ) {
for ( int j = i + 1 ; j < L-> Last; j++ ) {
if ( L-> A[ i] .tuoi > L-> A[ j] .tuoi ) {
struct Sinhvien tmp = L-> A[ i] ;
L-> A[ i] = L-> A[ j] ;
L-> A[ j] = tmp;
}
}
}
printf ( "Da sap xep theo tuoi\n " ) ; }
void SEARCH_BY_NAME( List L) {
char name[ 20 ] ;
printf ( "\n +==========================================================================+\n " ) ; printf ( "| TIM KIEM SINH VIEN THEO HO TEN |\n " ) ; printf ( "+==========================================================================+\n " ) ; printf ( ">> Nhap ten can tim: \n " ) ; int found = 0 ;
for ( int i = 0 ; i < L.Last ; i++ ) {
if ( strstr ( L.
A [ i
] .
name , name
) != NULL
) { found = 1 ;
struct Sinhvien sv = L.A [ i] ;
printf ( " Da tim thay sinh vien trong danh sach \n " ) ; printf ( "+==========================================================================+\n " ) ; printf ( "| Thong tin sinh vien: |\n " ) ; printf ( "| MSSV : %-59s|\n " , sv.
id ) ; printf ( "| Ho ten : %-59s|\n " , sv.
name ) ; printf ( "| Ngay sinh : %-27sTuoi : %-11d |\n " , sv.
ns , sv.
tuoi ) ; printf ( "+==========================================================================+\n " ) ; }
}
if ( ! found) {
printf ( " Khong tim thay sinh vien nao co ten chua tu khoa tren \n " ) ; }
}
// ================== MAIN ==================
int main( ) {
char * names[ ] = {
"NGUYEN DUC QUANG" ,
"TRAN MINH QUANG" ,
"LUONG VIET NHAT" ,
"HOANG GIA THE" ,
"NGUYEN TIEN DUNG"
} ;
char * ids[ ] = {
"2411061767" ,
"2411062029" ,
"2411061614" ,
"2411061927" ,
"2411061649"
} ;
int n = 5 ; // so thanh vien
printf ( "+==================================================================================+\n " ) ; printf ( "| BAI TAP LON BAI 7 - QUAN LI SINH VIEN | \n " ) ; printf ( "+==================================================================================+\n " ) ; printf ( "| %-30s | %-20s | |\n " , "THANH VIEN NHOM" , "MA SINH VIEN" ) ; printf ( "+----------------------------------------------------------------------------------+\n " ) ;
for ( int i = 0 ; i < n; i++ ) {
printf ( "| %-30s | :%-19s | | \n " , names
[ i
] , ids
[ i
] ) ; printf ( "+----------------------------------------------------------------------------------+\n " ) ; }
List L;
MAKENULL_LIST( & L) ;
int choice;
while ( 1 ) {
printf ( "\n +=================================================================+\n " ) ; printf ( "| HE THONG QUAN LY SINH VIEN |\n " ) ; printf ( "+=================================================================+\n " ) ; printf ( "| [1] Them sinh vien vao danh sach (INSERT_LIST) |\n " ) ; printf ( "| [2] Xoa sinh vien theo MSV (DELETE_BY_ID) |\n " ) ; printf ( "| [3] Nhap diem cho cac sinh vien |\n " ) ; printf ( "| [4] Tim kiem sinh vien theo MSV (LOCATE) |\n " ) ; printf ( "| [5] Tim kiem sinh vien theo ten (SEARCH_BY_NAME) |\n " ) ; printf ( "| [6] Sap xep danh sach theo ten (abc) |\n " ) ; printf ( "| [7] In danh sach sinh vien |\n " ) ; printf ( "| [8] Them mon hoc moi vao danh sach |\n " ) ;
printf ( "| [0] Thoat chuong trinh |\n " ) ; printf ( "+=================================================================+\n " ) ; printf ( ">> Nhap lua chon cua ban: " ) ;
if ( choice == 0 ) {
break ;
}
switch ( choice) {
case 1 : {
struct Sinhvien sv = nhapSinhVien( L) ;
Position p;
printf ( "Nhap Vi Tri Sinh Vien Muon Them Chen Vao Dau 1 Cuoi 2: " ) ; if ( p == 1 ) {
INSERT_LIST( sv, 1 , & L) ;
printf ( "Them sinh vien vao thanh cong. \n " ) ; }
else if ( p == 2 ) {
INSERT_LIST( sv, END( L) , & L) ;
printf ( "Them sinh vien vao thanh cong. \n " ) ; }
else {
printf ( "Lua chon khong hop le \n " ) ; }
break ;
}
case 2 : {
char id[ 20 ] ;
printf ( "\n +-----------------------------------------+\n " ) ; printf ( "| XOA SINH VIEN THEO MA SINH VIEN |\n " ) ; printf ( "+-----------------------------------------+\n " ) ; printf ( ">> Nhap MSV can xoa: " ) ; DELETE_BY_ID( id, & L) ;
break ;
}
case 3 : {
char id[ 20 ] ;
printf ( "\n +---------------------------------------------+\n " ) ; printf ( "| NHAP DIEM CHO CAC SINH VIEN |\n " ) ; printf ( "+---------------------------------------------+\n " ) ; // CHÚ Ý DUNG FOR LONG QUA CAC SINH VIEN VA DIEM NHA CAC BRO
break ;
}
case 4 : {
char id[ 20 ] ;
printf ( "\n +-----------------------------------------+\n " ) ; printf ( "| TIM KIEM SINH VIEN THEO MSV |\n " ) ; printf ( "+-----------------------------------------+\n " ) ; Position p = LOCATE( id, L) ;
if ( p == 0 || p == END( L) ) {
printf ( " Khong tim thay sinh vien co MSV: \n " , id
) ;
} else {
struct Sinhvien sv = RETRIEVE( p, L) ;
printf ( " Da tim thay sinh vien trong danh sach \n " ) ; printf ( "+==========================================================================+\n " ) ; printf ( "| Thong tin sinh vien: |\n " ) ; printf ( "| MSSV : %-59s|\n " , sv.
id ) ; printf ( "| Ho ten : %-59s|\n " , sv.
name ) ; printf ( "| Ngay sinh : %-27sTuoi : %-11d |\n " , sv.
ns , sv.
tuoi ) ; printf ( "+==========================================================================+\n " ) ; }
break ;
}
case 5 :
SEARCH_BY_NAME( L) ;
break ;
case 6 :
SORT_BY_NAME( & L) ;
break ;
case 7 :
PRINT_LIST( L) ;
break ;
case 8 : {
char mon[ 50 ] ;
printf ( "Nhap mon hoc can them\n " ) ;
break ;
}
break ;
case 9 :
default :
printf ( "Lua chon khong hop le\n " ) ; }
}
return 0 ;
}
/*
_______________________________________
|   Thành Viên Nhóm  |   Ma Sinh Viên |
|_____________________________________|
|	Nguy?n Ð?c Quang |	:2411061767	  |
|									  |
|	Tr?n Minh Quang	 |	:2411062029   |
|									  |
|	Lu?ng Vi?t Nh?t	 |	:2411061614   |
|									  |
|	Hoàng Gia Th?	 |	:2411061927   |
|									  |
|	Nguy?n Ti?n Dung |	:2411061649   |
|_____________________________________|
*/
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#define MAX 100
 
typedef int Position;
 
// Cau truc sinh vien
typedef struct {
    char tenMon[50];
 
} MonHoc;
 
struct Sinhvien {
    char id[20];
    char name[50];
    char ns[20];
    int tuoi;
    float diem[MAX]; 
    int soMon; 
};
 
// Kieu danh sach mang
typedef struct {
    struct Sinhvien A[MAX];
    int Last; 
} List;
 
 
 
// =============================== Cac thao tac co ban ===============================
 
Position FIRST(List L) {
    return 1;
}
 
Position END(List L) {
    return L.Last + 1;
}
 
Position NEXT(Position P, List L) {
    if (P < END(L)) return P + 1;
    return END(L);
}
 
Position PREVIOUS(Position P, List L) {
    if (P > FIRST(L)) return P - 1;
    return FIRST(L);
}
 
struct Sinhvien RETRIEVE(Position P, List L) {
    return L.A[P-1];
}
 
Position LOCATE(char id[], List L) {
    for (int i = 0; i < L.Last; i++) {
        if (strcmp(L.A[i].id, id) == 0)
            return i+1;
    }
    return END(L);
}
 
void MAKENULL_LIST(List *L) {
    L->Last = 0;
}
 
int EMPTY_LIST(List L){
    return L.Last == 0;
}
 
void INSERT_LIST(struct Sinhvien x, Position P, List *L) {
    if (L->Last >= MAX) {
        printf("Danh sach day\n");
        return;
    }
    if (P < FIRST(*L) || P > END(*L)) {
        printf("Vi tri khong hop le\n");
        return;
    }
    for (int i = L->Last; i >= P; i--) {
        L->A[i] = L->A[i-1];
    }
 
    L->A[P-1] = x;
    L->Last++;
}
 
void DELETE_LIST(Position P, List *L) {
    if (P < FIRST(*L) || P >= END(*L)) {
        printf("Vi tri khong hop le\n");
        return;
    }
    for (int i = P-1; i < L->Last-1; i++) {
        L->A[i] = L->A[i+1];
    }
    L->Last--;
}
 
 
 
// Xoa sinh vien theo MSV
void DELETE_BY_ID(char id[], List *L) {
    printf("\n+==========================================================================+\n");
    printf("|                         XOA SINH VIEN THEO MSV                           |\n");
    printf("+==========================================================================+\n");

    Position p = LOCATE(id, *L);

    if (p == END(*L)) {
        printf("|   Khong tim thay sinh vien co MSV: %-36s|\n", id);
        printf("+==========================================================================+\n");
        return;
    }

    struct Sinhvien sv = L->A[p - 1];

    char confirm;
    printf("|   Tim thay sinh vien:                                                    |\n");
    printf("|   MSSV      : %-59s|\n", sv.id);
    printf("|   Ho ten    : %-59s|\n", sv.name);
    printf("|   Ngay sinh : %-27sTuoi : %-11d              |\n", sv.ns, sv.tuoi);
    printf("+--------------------------------------------------------------------------+\n");
    printf("    Ban co chac chan muon xoa sinh vien nay khong? (y/n): ");
    scanf(" %c", &confirm);
    printf("+==========================================================================+\n");

    if (confirm != 'y' && confirm != 'Y') {
        printf("|   Da huy thao tac xoa sinh vien.                                        |\n");
        printf("+==========================================================================+\n");
        return;
    }

    for (int i = p - 1; i < L->Last - 1; i++) {
        L->A[i] = L->A[i + 1];
    }
    L->Last--;

    printf("|   Da xoa sinh vien thanh cong                                            |\n");
    printf("+--------------------------------------------------------------------------+\n");
    printf("|   Thong tin sinh vien da xoa:                                           |\n");
    printf("|   MSSV      : %-59s|\n", sv.id);
    printf("|   Ho ten    : %-59s|\n", sv.name);
    printf("|   Ngay sinh : %-27sTuoi : %-11d              |\n", sv.ns, sv.tuoi);
    printf("+==========================================================================+\n");
}




 
// ================== Cac chuc nang mo rong ==================
 
void ChuanHoan(char s[], int size) {
    for (int i = 0; i < size; i++) {
        if (s[i] == '/') {
            if (i == 1) { 
                for (int j = size; j >= 0; j--) {
                    s[j+1] = s[j];
                }
                s[0] = '0';
                size++;
            }
            if (s[i+2] == '/' && i+2 < size) {
                for (int k = size; k >= i+1; k--) {
                    s[k+1] = s[k];
                }
                s[i+1] = '0';
                size++;
            }
        }
    }
}
 
int laNamNhuan(int y) {
    return ( (y % 400 == 0) || (y % 4 == 0 && y % 100 != 0) );
}
 
int soNgayTrongThang(int m, int y) {
    if (m == 1 || m == 3 || m == 5 || m == 7 || m == 8 || m == 10 || m == 12)
        return 31;
    if (m == 4 || m == 6 || m == 9 || m == 11)
        return 30;
    if (m == 2)
        return laNamNhuan(y) ? 29 : 28;
    return 0; 
}
 
void ChuanHoaTen(char *name) {
    char temp[100];
    int i = 0, j = 0;
    int len = strlen(name);
 
    while (i < len && name[i] == ' ') i++;
    int space = 0; 
    while (i < len) {
        if (name[i] != ' ') {
            if (space && j > 0) {
                temp[j++] = ' '; 
                space = 0;
            }
            temp[j++] = name[i];
        } else {
            space = 1;
        }
        i++;
    }
 
    if (j > 0 && temp[j-1] == ' ') j--;
    temp[j] = '\0';
 
    for (i = 0; i < j; i++) {
        if (temp[i] >= 'A' && temp[i] <= 'Z')
            temp[i] = temp[i] - 'A' + 'a';
    }
 
    int newWord = 1;
    for (i = 0; i < j; i++) {
        if (temp[i] == ' ') {
            newWord = 1;
        } else if (newWord && temp[i] >= 'a' && temp[i] <= 'z') {
            temp[i] = temp[i] - 'a' + 'A';
            newWord = 0;
        } else {
            newWord = 0;
        }
    }
 
    strcpy(name, temp);
}
 
struct Sinhvien nhapSinhVien(List L) {
    struct Sinhvien sv;
    printf("\n+-----------------------------------------+\n");
    printf("|       NHAP THONG TIN SINH VIEN MOI      |\n");
    printf("+-----------------------------------------+\n");
	while (1) {
        printf(">> Nhap MSV: ");
        scanf("%s", sv.id);
        if (LOCATE(sv.id, L) != END(L)) {
            printf("MSSV da ton tai, nhap lai\n");
        } else {
            break;
        }
    }
 
 
 	int check;
 
    do {
        check = 1; 
        printf(">> Nhap ho ten: ");
        scanf(" %19[^\n]", sv.name); 
 
        for (int i = 0; i < strlen(sv.name); i++) {
            if (!((sv.name[i] >= 'a' && sv.name[i] <= 'z') || (sv.name[i] >= 'A' && sv.name[i] <= 'Z') || sv.name[i] == ' ')) {
                check = 0; 
                break;
            }
        }
 
        if (check == 0) {
            printf("Ho va ten khong chua so hoac ky tu dac biet (Nhap lai)\n");
        } else {
 
             ChuanHoaTen(sv.name);
 
        }
    } while (check == 0); 
 
  do {
    printf(">> Nhap ngay sinh (dd/mm/yyyy): ");
    scanf("%s", sv.ns);
 
    int size = strlen(sv.ns);
    ChuanHoan(sv.ns, size);
 
    char day[3], month[3], year[5];
    day[0] = sv.ns[0];
    day[1] = sv.ns[1];
    day[2] = '\0';
    month[0] = sv.ns[3];
    month[1] = sv.ns[4];
    month[2] = '\0';
    for (int i = 6, j = 0; i <= size; i++, j++) {
        year[j] = sv.ns[i];
        year[j+1] = '\0';
    }
 
    int d = atoi(day);
    int m = atoi(month);
    int y = atoi(year);
    int maxday = soNgayTrongThang(m,y);
    if (d <= 0 || d > maxday || m <= 0 || m > 12 || y <= 100) {
        printf("Ngay sinh khong hop le vui long nhap lai!\n");
    } else {
        int namNow = 2025;
	    do {
	        printf(">> Nhap tuoi: ");
	        scanf("%d", &sv.tuoi);
	        if (sv.tuoi < namNow - y - 2 || sv.tuoi > namNow - y + 2) {
	            printf("Vui long nhap lai tuoi dung voi tuoi that cua ban\n");
	        }
	    } while (sv.tuoi < namNow - y - 2 || sv.tuoi > namNow - y + 2);
        break; 
    }
} while (1);
 
 
	return sv;
}
 
void PRINT_LIST(List L) {
    if (L.Last == 0) {
        printf("Danh sach rong!\n");
        return;
    }
 
    printf("\n+-----+--------------+---------------------------+--------------+-------+\n");
    printf("| STT | MSSV         | Ho Ten                    | Ngay Sinh    | Tuoi  |\n");
    printf("+-----+--------------+---------------------------+--------------+-------+\n");
 
    for (int i = 0; i < L.Last; i++) {
        printf("| %-3d | %-12s | %-25s | %-12s | %-5d |\n",
               i+1, L.A[i].id, L.A[i].name, L.A[i].ns, L.A[i].tuoi);
    }
 
    printf("+-----+--------------+---------------------------+--------------+-------+\n");
}
 
void SORT_BY_NAME(List *L) {
    for (int i = 0; i < L->Last - 1; i++) {
        for (int j = i + 1; j < L->Last; j++) {
            if (strcmp(L->A[i].name, L->A[j].name) > 0) {
                struct Sinhvien tmp = L->A[i];
                L->A[i] = L->A[j];
                L->A[j] = tmp;
            }
        }
    }
    printf("Da sap xep theo ten\n");
}
 
void SORT_BY_TUOI(List *L) {
    for (int i = 0; i < L->Last - 1; i++) {
        for (int j = i + 1; j < L->Last; j++) {
            if (L->A[i].tuoi > L->A[j].tuoi) {
                struct Sinhvien tmp = L->A[i];
                L->A[i] = L->A[j];
                L->A[j] = tmp;
            }
        }
    }
    printf("Da sap xep theo tuoi\n");
}
 
void SEARCH_BY_NAME(List L) {
    char name[20];
    printf("\n+==========================================================================+\n");
    printf("|                      TIM KIEM SINH VIEN THEO HO TEN                      |\n");
    printf("+==========================================================================+\n");
	printf(">> Nhap ten can tim: \n");
    scanf(" %[^\n]", name);
    int found = 0;

    for (int i = 0; i < L.Last; i++) {
        if (strstr(L.A[i].name, name) != NULL) {
            found = 1;
            struct Sinhvien sv = L.A[i];

            printf("   Da tim thay sinh vien trong danh sach      \n");
            printf("+==========================================================================+\n");
            printf("|   Thong tin sinh vien:                                                   |\n");
            printf("|   MSSV      : %-59s|\n", sv.id);
            printf("|   Ho ten    : %-59s|\n", sv.name);
            printf("|   Ngay sinh : %-27sTuoi : %-11d              |\n", sv.ns, sv.tuoi);
            printf("+==========================================================================+\n");
        }
    }

    if (!found) {
        printf("   Khong tim thay sinh vien nao co ten chua tu khoa tren      \n");
    }
}

 
// ================== MAIN ==================
int main() {
	char *names[] = {
        "NGUYEN DUC QUANG",
        "TRAN MINH QUANG",
        "LUONG VIET NHAT",
        "HOANG GIA THE",
        "NGUYEN TIEN DUNG"
    };
 
    char *ids[] = {
        "2411061767",
        "2411062029",
        "2411061614",
        "2411061927",
        "2411061649"
    };
 
    int n = 5; // so thanh vien
 
    printf("+==================================================================================+\n");
    printf("|                              BAI TAP LON BAI 7 - QUAN LI SINH VIEN               |    \n");
    printf("|                                                                                  | \n");
    printf("|                                        LOP: DH14C4                               |    \n");
    printf("+==================================================================================+\n");
    printf("|               %-30s | %-20s |            |\n", "THANH VIEN NHOM", "MA SINH VIEN");
    printf("+----------------------------------------------------------------------------------+\n");
 
    for (int i = 0; i < n; i++) {
    printf("|               %-30s | :%-19s |            | \n", names[i], ids[i]);
    printf("+----------------------------------------------------------------------------------+\n");
    }
 
    List L;
    MAKENULL_LIST(&L);
 
 
 
    int choice;
    while (1) {
        printf("\n+=================================================================+\n");
        printf("|                     HE THONG QUAN LY SINH VIEN                  |\n");
        printf("+=================================================================+\n");
        printf("| [1] Them sinh vien vao danh sach (INSERT_LIST)              	  |\n");
        printf("| [2] Xoa sinh vien theo MSV (DELETE_BY_ID)                       |\n");
        printf("| [3] Nhap diem cho cac sinh vien                                 |\n");
        printf("| [4] Tim kiem sinh vien theo MSV (LOCATE)                        |\n");
        printf("| [5] Tim kiem sinh vien theo ten (SEARCH_BY_NAME)                |\n");
        printf("| [6] Sap xep danh sach theo ten (abc)                            |\n");
        printf("| [7] In danh sach sinh vien                                      |\n");
        printf("| [8] Them mon hoc moi vao danh sach                              |\n");
 
        printf("| [0] Thoat chuong trinh                                          |\n");
        printf("+=================================================================+\n");
        printf(">> Nhap lua chon cua ban: ");
        scanf("%d", &choice);
 
        if (choice == 0) {
            printf("Da thoat\n");
            break;
        }
        switch (choice) {
            case 1: {
                struct Sinhvien sv = nhapSinhVien(L);
                Position p;
                printf("Nhap Vi Tri Sinh Vien Muon Them Chen Vao Dau 1 Cuoi 2: ");
                scanf("%d", &p);
                if(p == 1 ){
                    INSERT_LIST(sv, 1, &L);	
                    printf("Them sinh vien vao thanh cong. \n");
				}
				else if(p == 2){
				    INSERT_LIST(sv, END(L), &L);
				    printf("Them sinh vien vao thanh cong. \n");	
				}
				else{
				    printf("Lua chon khong hop le \n");
				}
                break;
            }
            case 2: {
                char id[20];
                printf("\n+-----------------------------------------+\n");
                printf("|     XOA SINH VIEN THEO MA SINH VIEN     |\n");
                printf("+-----------------------------------------+\n");
                printf(">> Nhap MSV can xoa: ");
                scanf("%s", id);
                DELETE_BY_ID(id, &L);
                break;
            }
            case 3: {
                char id[20];
                printf("\n+---------------------------------------------+\n");
   			 	printf("|         NHAP DIEM CHO CAC SINH VIEN         |\n");
   				printf("+---------------------------------------------+\n");
   			// CHÚ Ý DUNG FOR LONG QUA CAC SINH VIEN VA DIEM NHA CAC BRO
                break;
            }
            case 4: {
 
                char id[20];
                printf("\n+-----------------------------------------+\n");
                printf("|       TIM KIEM SINH VIEN THEO MSV       |\n");
                printf("+-----------------------------------------+\n");
                printf(">> Nhap MSV: ");
                scanf("%s", id);
                Position p = LOCATE(id, L);
                if (p == 0 || p == END(L)) {
       		 printf("   Khong tim thay sinh vien co MSV: \n", id);
      		 
   		 } else {
     		   struct Sinhvien sv = RETRIEVE(p, L);
      				 printf("   Da tim thay sinh vien trong danh sach                        \n");
       				 printf("+==========================================================================+\n");
       				 printf("|   Thong tin sinh vien:                                                   |\n");
       				 printf("|   MSSV      : %-59s|\n", sv.id);
       				 printf("|   Ho ten    : %-59s|\n", sv.name);
       				 printf("|   Ngay sinh : %-27sTuoi : %-11d              |\n", sv.ns, sv.tuoi);
       				 printf("+==========================================================================+\n");
    }
    break;
}
            case 5: 
                SEARCH_BY_NAME(L);
                break;
 
            case 6:
                SORT_BY_NAME(&L);
                break;
            case 7:
                PRINT_LIST(L);
                break;
            case 8:{
            	char mon[50];
            	printf("Nhap mon hoc can them\n");
            	scanf("%s",mon);
 
				break;
			}
 
    			break;
            case 9:
 
            default:
                printf("Lua chon khong hop le\n");
        }
    }
    return 0;
}