C++通讯录管理系统

要求能按分类查询通讯录的信息,其中类别有:同事类,朋友类,商务类,一般类

参考:

#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;
}
}