单链表-姓名学号-创建/遍历/增添/删除

本文详细介绍了单链表的基本概念,并通过实例演示了如何创建、遍历、添加和删除链表节点。理解单链表的操作对于数据结构的学习至关重要。
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
struct Student{
    char Name[20];
    char Number[10];
    struct Student *next;
};
int Count;
struct Student *Create(){
    struct Student *pHead  = 0;
    struct Student *pEnd,*pNew;
    Count = 0;
    pEnd = pNew =(struct Student *)malloc(sizeof(struct Student));
    printf("请输入学生的姓名和学号:(姓名和学号都为0时结束录入)\n");
    scanf("%s",&pNew->Name);
    scanf("%s",&pNew->Number);
    while((strcmp("0",pNew->Number)!=0)||(strcmp("0",pNew->Name)!=0)){
        Count++;
        if(Count==1){
            pNew->next = pHead;
            pHead=pNew; 
            pEnd=pNew; 
        }
        else{
            pNew->next = 0;
            pEnd->next=pNew;
            pEnd=pNew;
        }
        pNew=(struct Student *)malloc(sizeof(struct Student));
        scanf("%s",&pNew->Name);
        scanf("%s",&pNew->Number);

    } 
    printf("\n信息录入成功\n\n"); 
    free(pNew); 
    return pHead;
} 
struct Student *AddNodeToTheHead(struct Student *pHead){
    struct Student *pNew;
    pNew = (struct Student *)malloc(sizeof(struct Student));
    printf("请输入添加到开头的学生姓名、学号:(输入cancel中止添加)\n");
    scanf("%s",&pNew->Name);
    if(strcmp("cancel",pNew->Name)==0)return pHead;
    scanf("%s",&pNew->Number); 
    pNew->next = pHead;
    pHead = pNew;
    Count++; 
    printf(
#include <iostream> #include <string> using namespace std; // 定义学生结构体,用于表示链表中的一个节点 typedef struct Student { int number; // 学号 string name; // 姓名(使用 C++ string 类型) int score; // 成绩 Student* next; // 指向下一个节点的指针 } stu; // 初始化链表:创建一个头节点 stu* initlist() { stu* head = new stu; // 动态分配头节点内存 head->next = NULL; // 初始时头节点指向空 return head; // 返回头节点指针 } // 添加学生信息到链表(头插法),并确保学号不重复 void Add(stu* head) { if (head == NULL) { cout << "头节点为空,无法添加!" << endl; return; } stu* st = head->next; // st 用于遍历链表,检查学号是否已存在 stu* p = new stu; // 动态创建一个新的学生节点 p,准备用来存放用户即将输入的新学生信息 cout << "请输入学生学号" << endl; cin >> p->number; int t = p->number;//将录入的学生的学号信息存储在临时变量t中 // 遍历链表,检查是否有相同学号的学生 while (st) { if (st->number != t) { st = st->next;//如果t与当前节点的学号信息不同,就继续沿链表向下寻找 } else { cout << "该学号已存在录入错误,请重新选择" << endl; return; // 学号重复,退出函数,不插入 } } // 输入姓名和成绩 cout << "请输入学生姓名:" << endl; cin >> p->name; cout << "请输入学生成绩:" << endl; cin >> p->score; // 头插法:将新节点插入到链表头部(head->next 的位置) p->next = head->next; // 新节点指向原来的第一个节点 head->next = p; // 头节点指向新节点 } // 删除指定学号的学生节点 void Delete(stu* head) { if (head == NULL) { cout << "链表头节点不存在" << endl; return; } stu* pre = head; // pre 指向前一个节点,用于删除操作 stu* p = head->next; // p 指向当前遍历的节点 int a; cout << "请输入你要删除学生的学号" << endl; cin >> a; // 遍历链表查找目标学号 while (p != NULL) { if (p->number == a) { pre->next = p->next; // 跳过当前节点 delete p; // 删除节点p即输入学号所在的节点,释放内存 cout << "删除成功" << endl; return; } else {//当前节点的学号信息和要删除学号不同,就沿着链表继续向后找,pre和p均向前走一步 pre = p; // pre 向前走一步 p = p->next; // p 向前走一步 } } cout << "没有找到该学生"; } // 查找指定学号的学生并输出其信息 void Search(stu* head) { if (head == NULL) { cout << "链表头节点不存在" << endl; return; } stu* p = head->next; // 从第一个有效节点开始查找 int a; cout << "请输入你要查找学生的学号" << endl; cin >> a; while (p != NULL) { if (p->number == a) { cout << "学号\t\t" << "姓名\t" << "成绩" << endl; cout << p->number << "\t\t" << p->name << "\t" << p->score << endl;//若当前节点是所寻找的节点就输出该结点的信息 return; } else { p = p->next;//若当前节点的学号与所寻找的不同,就向下继续寻找 } } cout << "没有找到该学生" << endl; } // 遍历整个链表,打印所有学生信息 void Traversal(stu* head) { if (head == NULL) { cout << "错误:头节点为空!" << endl; return; } stu* p = head->next; cout << "学号\t\t" << "姓名\t" << "成绩" << endl; while (p != NULL) {//while循环遍历输出所有学生的信息 cout << p->number << "\t\t" << p->name << "\t" << p->score << endl; p = p->next; } } // 对链表按成绩从高到低进行冒泡排序 void Sort(stu* head) { // 如果链表为空或只有一个节点,则无需排序 if (!head->next || !head->next->next) return; bool flag = true; // 标志位,判断是否发生交换 stu* p; // 冒泡排序外层循环:持续遍历直到某次没有发生交换 while (flag) { flag = false; p = head->next; // 内层遍历:比较相邻两个节点的成绩 while (p && p->next) { if (p->score < p->next->score) { // 交换三个字段:学号、成绩、姓名 int tn = p->number; p->number = p->next->number; p->next->number = tn; int ts = p->score; p->score = p->next->score; p->next->score = ts; string ta = p->name; p->name = p->next->name; p->next->name = ta; flag = true; // 发生了交换,设置标志 } p = p->next; } } } // 主函数 int main() { int a; cout << "退出0 添加1 删除2 查找3 排序4 遍历5" << endl; stu* head = initlist(); // 初始化链表 while (1) { cout << "请选择:" << endl; cin >> a; switch (a) { case 0: cout << "程序运行结束"; return 0; case 1: Add(head); break; case 2: Delete(head); break; case 3: Search(head); break; case 4: Sort(head); cout << "排序完成请遍历后查看" << endl; break; case 5: Traversal(head); break; default: cout << "无效选择,请重新输入" << endl; break; } } }根据这段代码,给出相应的完整的伪代码
最新发布
12-29
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值