1. 定義鏈表節(jié)點結構:首先定義一個結構體來表示鏈表中的每個節(jié)點,通常包含學生的基本信息和成績。
```c
typedef struct Student {
int id; // 學生ID
char name[50]; // 學生姓名
float score; // 成績
struct Student next; // 指向下一個節(jié)點的指針
} Student;
```
2. 初始化鏈表:創(chuàng)建一個函數(shù)來初始化鏈表,通常設置一個頭節(jié)點(哨兵節(jié)點)。
```c
Student initList() {
Student head = (Student )malloc(sizeof(Student));
head->next = NULL;
return head;
}
```
3. 添加成績:創(chuàng)建一個函數(shù)來添加新的學生成績到鏈表末尾。
```c
void addScore(Student head, int id, c*t char name, float score) {
Student newStudent = (Student )malloc(sizeof(Student));
newStudent->id = id;
strcpy(newStudent->name, name);
newStudent->score = score;
newStudent->next = NULL;
Student current = head;
while (current->next != NULL) {
current = current->next;
}
current->next = newStudent;
}
```
4. 刪除成績:創(chuàng)建一個函數(shù)來根據(jù)學生ID刪除對應的成績節(jié)點。
```c
void deleteScore(Student head, int id) {
Student current = head;
Student prev = NULL;
while (current != NULL && current->id != id) {
prev = current;
current = current->next;
}
if (current == NULL) {
printf("Student not found.\n");
} else {
if (prev == NULL) {
// 刪除頭節(jié)點
head = current->next;
} else {
prev->next = current->next;
}
free(current);
}
}
```
5. 查找成績:創(chuàng)建一個函數(shù)來根據(jù)學生ID查找成績。
```c
Student findScore(Student head, int id) {
Student current = head->next; // 跳過哨兵節(jié)點
while (current != NULL) {
if (current->id == id) {
return current;
}
current = current->next;
}
return NULL; // 未找到
}
```
6. 打印鏈表:創(chuàng)建一個函數(shù)來遍歷鏈表并打印所有學生的成績信息。
```c
void printList(Student head) {
Student current = head->next; // 跳過哨兵節(jié)點
while (current != NULL) {
printf("ID: %d, Name: %s, Score: %.2f\n", current->id, current->name, current->score);
current = current->next;
}
}
```
7. 釋放鏈表內存:創(chuàng)建一個函數(shù)來釋放鏈表占用的所有內存。
```c
void freeList(Student head) {
Student current = head->next;
while (current != NULL) {
Student temp = current;
current = current->next;
free(temp);
}
free(head); // 釋放頭節(jié)點
}
```
這些基本操作提供了學生成績管理系統(tǒng)的框架。你可以根據(jù)自己的需求添加更多的功能,如更新成績、排序顯示等。記得在編寫代碼時,要考慮到邊界條件和內存管理,以避免潛在的錯誤和內存泄漏。