用C++弄学生管理系统,要求有添加,删除,修改,查询,检索等功能.......
答案:1 悬赏:50 手机版
解决时间 2021-03-20 01:45
- 提问者网友:溺爱和你
- 2021-03-19 19:32
用C++弄学生管理系统,要求有添加,删除,修改,查询,检索等功能.......
最佳答案
- 五星知识达人网友:逐風
- 2021-03-19 20:14
链表
#include
#include
#define LEN sizeof(struct student)
//定义一个学生信息的结构体,包括学号,姓名和结构体类型的指针
struct student
{
long num; //学号
char name[128]; //姓名
struct student *next; //结构体指针
};
typedef struct student * stuNode;
int n = 0; //全局变量,记录链表的长度
stuNode Create(); //创建一个新的链表
void Print(stuNode head); //通过传入的链表头指针打印整个链表
stuNode Delete(stuNode head, int num); //通过传入的链表头指针和学生学号删除节点
stuNode Insert(stuNode head, stuNode newStu); //依照学生学号的顺序向链表中插入新元素
struct student *Create()
{
struct student *head, *p1, *p2;
//开辟一个LEN大小的空间,并让p1,p2指针指向它
p2 = p1 = (struct student *)malloc(LEN);
//将头指针置为NULL
head = NULL;
//创建链表节点并给节点的元素赋值
printf("请输入学生的学号和姓名:");
scanf("%ld %s", &p1->num, p1->name);
while (p1->num != 0)
{
n = n + 1;
if (NULL == head)
{
head = p1;
}
else
{
p2->next = p1;
}
p2 = p1;
p1 = (struct student *)malloc(LEN);
printf("请输入学生的学号和姓名:");
scanf("%ld %s", &p1->num, p1->name);
}
//将尾节点的指针置为NULL
p2->next = NULL;
return head;
}
void Print(struct student *head)
{
struct student * p;
p = head;
//判断链表是否为空
if (NULL == head)
{
printf("链表为空!
");
return ;
}
else
{
//循环打印链表中的元素
printf("%d 个记录分别为:
", n);
while (p != NULL)
{
printf("%ld %s
", p->num, p->name);
//指针指向下一个节点
p = p->next;
}
}
}
struct student *Delete(struct student * head, int num)
{
struct student *p1;
struct student *p2;
p1 = head;
//判断链表是否为空
if (NULL == head)
{
printf("链表为空!
");
return head;
}
//遍历节点,判断当前节点是不是需要删除的节点及是否为尾节点
//如果找到相应节点,或者已经遍历到尾节点就跳出循环
while (p1->num != num&&p1->next != NULL)
{
p2 = p1;
p1 = p1->next;
}
//判断是否找到相应节点
if (p1->num == num)
{
//要删除的节点是不是链表的第一个节点
//如果是,就将头指针指向该节点的后一个节点
//如果不是,就将该节点的前一个节点的指针指向该节点的后一个节点
if (head == p1)
{
head = p1->next;
}
else
{
p2->next = p1->next;
}
n = n - 1;
printf("%ld 节点已删除.
", num);
}
else
{
printf("链表中没有要删除的元素.
");
}
return head;
}
struct student *Insert(struct student * head, struct student * newStu)
{
struct student *p0;
struct student *p1;
struct student *p2;
p0 = newStu;
p1 = head;
//判断链表是否为空,如果是空链表,就将新节点作为第一个节点
if (NULL == head)
{
head = p0;
p0->next = NULL;
}
else
{
//遍历每一个节点中的学号,与新学号比较大小
//如果找到一个学号比新学号大,就将新学号的节点插入它之前
//如果尾节点的学号仍比新学号小,就将新节点插入到链表尾部
while ((p0->num > p1->num) && (p1->next != NULL))
{
p2 = p1;
p1 = p1->next;
}
//找到一个比新学号大的节点
if (p0->num <= p1->num)
{
//判断该节点是否为头节点,如果是,则将新节点设置为头节点
if (p1 == head)
{
head = p0;
}
else
{
p2->next = p0;
}
p0->next = p1;
}
else
{
p1->next = p0;
p0->next = NULL;
}
}
//链表长度加1
n = n + 1;
printf("%ld 插入成功!
", newStu->num);
return head;
}
void main()
{
struct student *head;
struct student *stu;
int num;
head = Create();
Print(head);
printf("请输入要删除的学号:(结束)");
scanf("%ld", &num);
while (num != 0)
{
head = Delete(head, num);
Print(head);
printf("请输入要删除的学号:");
scanf("%ld", &num);
}
printf("请输入要插入的节点:");
stu = (struct student *)malloc(LEN);
scanf("%ld %s", &stu->num, stu->name);
while (stu->num != 0)
{
head = Insert(head, stu);
printf("请输入要插入的节点:");
stu = (struct student *)malloc(LEN);
scanf("%ld %s", &stu->num, stu->name);
}
Print(head);
}
#include
#include
#define LEN sizeof(struct student)
//定义一个学生信息的结构体,包括学号,姓名和结构体类型的指针
struct student
{
long num; //学号
char name[128]; //姓名
struct student *next; //结构体指针
};
typedef struct student * stuNode;
int n = 0; //全局变量,记录链表的长度
stuNode Create(); //创建一个新的链表
void Print(stuNode head); //通过传入的链表头指针打印整个链表
stuNode Delete(stuNode head, int num); //通过传入的链表头指针和学生学号删除节点
stuNode Insert(stuNode head, stuNode newStu); //依照学生学号的顺序向链表中插入新元素
struct student *Create()
{
struct student *head, *p1, *p2;
//开辟一个LEN大小的空间,并让p1,p2指针指向它
p2 = p1 = (struct student *)malloc(LEN);
//将头指针置为NULL
head = NULL;
//创建链表节点并给节点的元素赋值
printf("请输入学生的学号和姓名:");
scanf("%ld %s", &p1->num, p1->name);
while (p1->num != 0)
{
n = n + 1;
if (NULL == head)
{
head = p1;
}
else
{
p2->next = p1;
}
p2 = p1;
p1 = (struct student *)malloc(LEN);
printf("请输入学生的学号和姓名:");
scanf("%ld %s", &p1->num, p1->name);
}
//将尾节点的指针置为NULL
p2->next = NULL;
return head;
}
void Print(struct student *head)
{
struct student * p;
p = head;
//判断链表是否为空
if (NULL == head)
{
printf("链表为空!
");
return ;
}
else
{
//循环打印链表中的元素
printf("%d 个记录分别为:
", n);
while (p != NULL)
{
printf("%ld %s
", p->num, p->name);
//指针指向下一个节点
p = p->next;
}
}
}
struct student *Delete(struct student * head, int num)
{
struct student *p1;
struct student *p2;
p1 = head;
//判断链表是否为空
if (NULL == head)
{
printf("链表为空!
");
return head;
}
//遍历节点,判断当前节点是不是需要删除的节点及是否为尾节点
//如果找到相应节点,或者已经遍历到尾节点就跳出循环
while (p1->num != num&&p1->next != NULL)
{
p2 = p1;
p1 = p1->next;
}
//判断是否找到相应节点
if (p1->num == num)
{
//要删除的节点是不是链表的第一个节点
//如果是,就将头指针指向该节点的后一个节点
//如果不是,就将该节点的前一个节点的指针指向该节点的后一个节点
if (head == p1)
{
head = p1->next;
}
else
{
p2->next = p1->next;
}
n = n - 1;
printf("%ld 节点已删除.
", num);
}
else
{
printf("链表中没有要删除的元素.
");
}
return head;
}
struct student *Insert(struct student * head, struct student * newStu)
{
struct student *p0;
struct student *p1;
struct student *p2;
p0 = newStu;
p1 = head;
//判断链表是否为空,如果是空链表,就将新节点作为第一个节点
if (NULL == head)
{
head = p0;
p0->next = NULL;
}
else
{
//遍历每一个节点中的学号,与新学号比较大小
//如果找到一个学号比新学号大,就将新学号的节点插入它之前
//如果尾节点的学号仍比新学号小,就将新节点插入到链表尾部
while ((p0->num > p1->num) && (p1->next != NULL))
{
p2 = p1;
p1 = p1->next;
}
//找到一个比新学号大的节点
if (p0->num <= p1->num)
{
//判断该节点是否为头节点,如果是,则将新节点设置为头节点
if (p1 == head)
{
head = p0;
}
else
{
p2->next = p0;
}
p0->next = p1;
}
else
{
p1->next = p0;
p0->next = NULL;
}
}
//链表长度加1
n = n + 1;
printf("%ld 插入成功!
", newStu->num);
return head;
}
void main()
{
struct student *head;
struct student *stu;
int num;
head = Create();
Print(head);
printf("请输入要删除的学号:(结束)");
scanf("%ld", &num);
while (num != 0)
{
head = Delete(head, num);
Print(head);
printf("请输入要删除的学号:");
scanf("%ld", &num);
}
printf("请输入要插入的节点:");
stu = (struct student *)malloc(LEN);
scanf("%ld %s", &stu->num, stu->name);
while (stu->num != 0)
{
head = Insert(head, stu);
printf("请输入要插入的节点:");
stu = (struct student *)malloc(LEN);
scanf("%ld %s", &stu->num, stu->name);
}
Print(head);
}
我要举报
如以上问答信息为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
推荐资讯