m0_51598294 2021-09-21 15:24 采纳率: 50%
浏览 42
已结题

SOS!数据结构单链表实验题目求解

实验内容及要求
实验内容:
1.完成线性表链式存储结构的若干典型算法(典型算法可自选)。
学生表维护(用链式存储结构)
(1)建立学生表(前插法、后插法)
(2)输出学生表
(3)添加新同学,使之成为第i号
(4)删除第i号学生
(5)输出学生表的长度
(6)删除指定年龄的学生信息
struct Student {
string id;//学号
string name;//学生姓名
int age;//年龄
}Stu;
2.有一个单链表的第一个结点指针为head,编写一个函数将该单链表逆置,即最后一个结点变成第一个结点,原来倒数第二个结点变成第二个结点。在逆置中不能建立新的单链表。

实验要求:
1.键盘输入数据;
2.屏幕输出运行结果。
3.要求记录实验源代码及运行结果。
4.运行环境:CodeBlocks/Dev C++/VC6.0等C编译环境

  • 写回答

2条回答 默认 最新

  • 关注

    参考:

    #include<stdio.h>
    #include<string.h>
    #include<stdlib.h>
    #include<windows.h>
    struct stu //第一部分:声明结构体类型struct stu 
    {
        char name[100];//姓名为字符串型
        int xh;//学号为整形
        int grade;//年级
        char cel[15];//手机
        char tel[50];//电话
        char mail[50];//邮件
        char add[100];//地址为字符串型
        char post[15];//邮编
        struct stu *next;//用指针处理链表,next是指针变量,指向结构体变量
    };
    struct stu *charu(struct stu *head,struct stu *q)//第二部分:插入函数(插入新结点)
    {
        struct stu *p;
        for(p=head;p->next!=NULL;p=p->next);//for(使p也指向head;当p为空文件时 ;p指向下一个结点)
        p->next=q;
        q->next=NULL;
        return head;
    }
    void search(struct stu *head) //第三部分:查找结点并输出
    {    
        struct stu *p;
        int a;//要查找学生的学号
        if(head->next==NULL)//头文件为空时打印出的结果为"通讯录为空"
            printf("**********************************通讯录为空!!!*********************************\n\n\n");
        else//头文件不为空时,开始查询学生的信息
        {
            printf("\t输入要查询学生学号:");
            scanf("%d",&a);
            for(p=head->next;p->next!=NULL;p=p->next)//for(使p也指向head;当p为空文件时 ;p指向下一个结点)
            {
                if(p->xh==a) //如果输入的学号和某个相同,输出以下的东西。
                {
                    printf("   要查找的学生信息为:\n");
                    printf("       ★姓名:");puts(p->name);
                    printf("\t学号: ");printf("%d",p->xh);
                    printf("\t年级:");printf("%d\n",p->grade);
                    printf("\t手机:");puts(p->cel);
                    printf("\t电话:");puts(p->tel);
                    printf("\t邮箱:");puts(p->mail);
                    printf("\t地址");puts(p->add);
                    printf("\t邮编:");puts(p->post);
                    printf("\t查找成功!!!");
                    printf("\n\n\n");
                    break;
                }
            }
        if(p->xh==a)
            {
                printf("   要查找的学生信息为:\n");
                printf("     ★姓名:");puts(p->name);
                printf("\t年级:");printf("%d\n",p->grade);
                printf("\t手机:");puts(p->cel);
                printf("\t电话:");puts(p->tel);
                printf("\t邮箱:");puts(p->mail);
                printf("\t地址");puts(p->add);
                printf("\t邮编:");puts(p->post);
                printf("\t查找成功!!!");
                printf("\n\n\n");
            }
        else printf("no people have found!!!\n");//如果不符合,就输出没有找到
        }
    }
    struct stu *del(struct stu *head) //第四部分:删除结点
    {
        struct stu *p,*q;
        int a;//要删除学生的学号
        if(head->next==NULL)// 头文件为空时,输出通讯录为空
            printf("**********************************通讯录为空!!!*********************************\n\n\n");
        else
        {
            printf("\t输入要删除学生学号:");
            scanf("%d",&a);
            for(p=head,q=p->next;q->xh!=a&&q->next!=NULL;)
            {
            p=p->next;
            q=p->next;
            }
            if(q->xh==a)
            {
                p->next=q->next;
                free(q);//释放q,也就是删除q,在这里就是删除q(学号为a)
                printf("删除成功!!!\n");
            }
            else printf("no people have found!!!");//如果不符合,就输出没有找到
        }
        return head;//返回头文件
    }
    struct stu *change(struct stu *head)  //第五部分:修改结点内容
    {
            int b,a,c;
        struct stu *p;
        if(head->next==NULL)// 头文件为空时,输出通讯录为空
        printf("**********************************通讯录为空!!!*********************************\n\n\n");
        else
        {
            printf("    输入要修改学生学号:");
            scanf("%d",&a);
            for(p=head->next;p!=NULL;p=p->next)
            {    
                start:printf("       输入想要修改什么?\n");
                printf("\t\t\t    1:修改姓名\n");
                    printf("\t\t\t    2:修改学号\n");
                    printf("\t\t\t    3:修改年级\n");
                    printf("\t\t\t    4:手机\n");
                    printf("\t\t\t    5:电话\n");
                    printf("\t\t\t    6:邮件\n");
                    printf("\t\t\t    7:地址\n");
                    printf("\t\t\t    8:邮编\n");
                    printf("          请输入你的选择:");
                    scanf("%d",&b);
                    switch(b)//先通过学号找到该学生,然后用switch语句选择修改项,再用switch和goto语句实现是否循环
                    {
                        case 1:
                            printf("\t输入新姓名:");
                            scanf("%s",p->name);break;
                        case 2:printf("\t输入新学号:");
                            scanf("%d",&p->xh);break;
                        case 3:
                            printf("\t输入新的年级:");
                            scanf("%d",&p->grade);break;
                        case 4:
                            printf("\t输入新的手机号:");
                            scanf("%s",p->cel);break;
                        case 5:
                            printf("\t输入新的电话号:");
                            scanf("%s",p->tel);break;
                        case 6:
                            printf("\t输入新的邮箱:");
                            scanf("%s",p->mail);break;
                        case 7:
                            printf("\t输入新的地址:");
                            scanf("%s",p->add);break;
                        case 8:
                            printf("\t输入新的邮编;");
                            scanf("%s",p->post);break;
                        default: printf("输入操作错误,请重新输入:"); 
                    }
                    printf("修改成功!!!\n");
                    printf("    是否要修改其他项? 1:是  2:否\n");
                    printf("       请输入你的选择:");
                        scanf("%d",&c);
                    switch(c) //goto语句实现是否循环
                    {
                        case 1:goto start;
                        case 2:break;
                    }
            }
        }
        return head;   //返回头文件
    }
    void printall(struct stu *head) //第六部分:输出全部通讯录
    {
        struct stu *p=head->next;
        while(1)
        {        
            if(p==NULL)  
            {
                printf("**********************************通讯录为空!!!*********************************\n\n\n");
                break;
            }
            else if(p->next==NULL)
            {
                printf("      ★姓名:");puts(p->name);
                printf("\t学号:");printf("%d\n",p->xh);
                printf("\t年级:");printf("%d\n",p->grade);
                printf("\t手机:");puts(p->cel);
                printf("\t电话:");puts(p->tel);
                printf("\t邮箱:");puts(p->mail);
                printf("\t地址:");puts(p->add);
                printf("\t邮编:");puts(p->post);
                printf("输出成功!!!\n");
                printf("\n\n\n");
                break;
            }
            else 
            {
                    printf("      ★姓名:");puts(p->name);
                    printf("\t学号:");printf("%d\n",p->xh);
                    printf("\t年级:");printf("%d\n",p->grade);
                    printf("\t手机:");puts(p->cel);
                    printf("\t电话:");puts(p->tel);
                    printf("\t邮箱:");puts(p->mail);
                    printf("\t地址:");puts(p->add);
                    printf("\t邮编:");puts(p->post);
                    printf("\n");
                    p=p->next;
                    continue;
            }
            printf("输出成功!!!\n");
        }
    }
    void sf(struct stu *head) //第八部分:释放结点退出系统
    {
            struct stu *p=head ;
            printf("释放链表:\n");
            while(p!=NULL)
            {
                head=head->next;
                free(p);
                p=head;
            }
            printf("释放链表成功!!!\n");
    }
    int main()// 第九部分:主函数框架
    {
        int cz;//操作符
        struct stu *head,*q;
        head=(struct stu*)malloc(sizeof(struct stu));//动态链表malloc
        head->next=NULL;//使next指向下一个结点,next结点不放其他结点地址
        system("color 1e");//修改dos窗口前背景色,用两个十六进制数表示
        printf("班级:    姓名:   学号:   设计课题:个人通讯录管理系统\n");
        printf("\n********************************C语言课程设计***********************************\n");
        printf("    *******************★个人通讯录管理系统★*****************\n\n\n");
        printf("    *            1:新建通讯录            *\n");
        printf("    *            2:删除通讯录            *\n");
        printf("    *            3:修改通讯录            *\n");
        printf("    *            4:查询通讯录            *\n");
        printf("    *            5:显示全部记录            *\n");
        printf("    *            6:释放链表并结束程序        *\n");
        printf("    *********************************************************\n");
    start :printf("输入操作符1-6:");//"输入操作符1-
        scanf("%d",&cz);
        switch(cz)//switch语句
        {
            case 1:
                    q=(struct stu *)malloc(sizeof(struct stu));
                    printf("\t输入姓名:");scanf("%s",q->name);
                    printf("\t输入学号:");scanf("%d",&q->xh);
                    printf("\t输入年级:");scanf("%d",&q->grade);
                    printf("\t手机号:");scanf("%s",q->cel);
                    printf("\t家庭电话:");scanf("%s",q->tel);
                    printf("\t输入电子邮件:");scanf("%s",q->mail);
                    printf("\t通讯录地址:");scanf("%s",&q->add);
                    printf("\t输入邮编:");scanf("%s",&q->post);
                    charu(head,q);
                    printf("插入成功!!!\n");break;
            case 2://删除
                head=del(head);break;
            case 3:
                change(head);break;//修改学生信息
            case 4:
                search(head);break;//查找结点head
            case 5:
                printall(head);break; //保存文件
            case 6: //释放结点退出系统
                sf(head);
                exit (0);
            default: printf("输入操作错误,重新");  //什么也不符合就"输入操作错误,重新"
        }
        goto start;//用goto语句实现循环操作
        return 0;
    }
    
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 10月28日
  • 已采纳回答 10月20日
  • 创建了问题 9月21日