通讯录系统加个排序功能,按姓名,年龄排都行

通讯录系统加个排序功能,按姓名,年龄排都行

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
typedef struct student
{
    char name[20];// 姓名 
    char wm[20];//性别 
    char stel[20];//手机号码 
    char home[100];//家庭住址 
    struct student* next;
}stu;
stu* head;//头指针 
void screen()//主菜单 
{
    printf("\n=======================================================\n");
    printf("              欢迎来到通讯录管理系统\n\n");
    printf("            1.输入数据         2.显示数据\n");
    printf("            3.增添数据         4.删除数据\n");
    printf("            5.查询数据         6.修改数据\n");
    printf("            7.保存数据         8.返回菜单\n");
    printf("\n~~~~~~输~~~~~~入~~~~~~9~~~~~~退~~~~~~出~~~~~~程~~~~~~序\n");
}
void input()//输入数据 
{
    int ans;//判断是否继续输入 
    stu* p1, * p2;
    p1 = (stu*)malloc(sizeof(stu));//申请内存来用 
    if (p1 != NULL)
    {
        printf("========输入数据========\n");
        head = p1;
        while (1)
        {
            printf("名字:");
            scanf("%s", &(*p1).name);
            printf("性别:");
            scanf("%s", &(*p1).wm);
            printf("手机:");
            scanf("%s", &(*p1).stel);
            printf("家庭地址:");
            scanf("%s", &(*p1).home);
            printf("===================================\n");
            p2 = p1;
            p1 = (stu*)malloc(sizeof(stu));//申请下一个要用的空间 
            if (p1 != NULL)
                (*p2).next = p1;
            printf("请选择是否继续输入:1.继续  2.退出\n请选择:");//用户选择 
            scanf("%d", &ans);
            if (ans == 1)//继续 
                continue;
            else//退出 
            {
                printf("========输入完毕========\n");
                (*p2).next = NULL;
                free(p1);//将申请的无用内存释放 
                break;
            }
        }
    }
}
void look() 
{
    FILE *fp;
    char file[15];
    printf("请输入文件名:");
    scanf("%s",file);
    fp=fopen(file, "a+");//打开文件
    stu *p1 = head;//准备遍历链表 拿到头结点
    printf("========显示数据========\n");
    while (p1 != NULL)
    {
        printf("名字:%s\n", p1->name);
        printf("性别:%s\t", p1->wm);
        printf("手机:%s\t", p1->stel);
        printf("家庭住址:%s\n", p1->home);
        printf("=====================================\n");
        p1 = p1->next;
    }
    printf("========显示完毕========\n");
}
void init()
{
    FILE* fp; 
    stu* p, * t;
    head = (stu*)malloc(sizeof(stu)); //修改1,这里直接用head
    head->next = 0;
    p = head;
    int count = 0;
    char file[15];
    printf("初始化...\n请输入加载数据的文件名:");
    scanf("%s", file);
    //到重新打开文件这里
    fp = fopen(file, "r");
    if (fp) //在这里判断文件是否打开就可以
    {
        while (!feof(fp))
        {
            stu* t = (stu*)malloc(sizeof(stu)); //
            t->next = 0;
            if (fscanf(fp, "%s%s%s%s", t->name, t->wm, t->stel, t->home))
            {
                p->next = t;
                p = t;
                count++;
            }
            else
                free(t);
        }
        fclose(fp);
    }
    else
    {
        printf("返回主菜单!\n");
        return;
    }
}
void insert()//插入数据 
{
    int ans;//选择插入位置 
    char name[20];//插入者的名字 
    printf("========增添数据========\n");
    stu* p1, * p2, * p3;
    p1 = head;
    p3 = (stu*)malloc(sizeof(stu));//申请内存 
    (*p3).next = NULL;
    printf("请输入插入者的数据:\n");
    printf("名字:");
    scanf("%s", &(*p3).name);
    printf("性别:");
    scanf("%s", &(*p3).wm);
    printf("手机:");
    scanf("%s", &(*p3).stel);
    printf("家庭地址:");
    scanf("%s", &(*p3).home);
    printf("请选择插入位置:1.首部加入  2.尾部加入");
    scanf("%d", &ans);
    switch (ans)
    {
    case 1://放到头指针 
        (*p3).next = p1;
        head = p3;
        break;
    case 2://放到尾部 
        while ((*p1).next != NULL)
            p1 = (*p1).next;
        (*p1).next = p3;
        break;
    }
    printf("========增添成功========\n");
}
void deleted()//删除数据 
{
    stu* p1, * p2 = NULL;
    char name[20];//删除者名字 
    printf("========删除数据========\n");
    printf("请输入要删除者的名字:");
    scanf("%s", name);
    p1 = head;
    if (head == NULL)//已经没有可删除的数据了 
    {
        printf("通讯录里什么也没有了。\n");
        printf("========删除失败========\n");
        return;
    }
    if (!strcmp(name, (*p1).name))//头指针就是要删除的,单独拿出来,就是为了可以在删除后改变头指针
    {
        head = (*p1).next;
        printf("========删除成功========\n");
        return;
    }
    while (p1 != NULL && strcmp(name, (*p1).name))
    {
        p2 = p1;
        p1 = (*p1).next;
    }
    if (p1 == NULL)//查找完了,没找到 
    {
        printf("查无此人!\n");
        printf("========删除失败========\n");
        return;
    }
    if ((*p1).next != NULL)//找到了,不是最后一个 
    {
        p1 = (*p1).next;
        (*p2).next = p1;
        printf("========删除成功========\n");
    }
    else//是最后一个 
    {
        (*p2).next = NULL;
        printf("========删除成功========\n");
    }
}
void find(stu* p1)//查找数据 
{
    char name[20];//查找者的名字 
    char stel[20];
    int n;
    printf("========查询数据========\n");
    printf("请选择查询方式:\n1.名字查询\n2.号码查询\n");
    scanf("%d", &n);
    if (n == 1)
    {
        printf("请输入名字:");
        scanf("%s", name);
    }
    if (n == 2)
    {
        printf("请输入号码:");
        scanf("%s", stel);
    }
    while (p1 != NULL)
    {
        if (strcmp(stel, (*p1).stel) == 0 || strcmp(name, (*p1).name) == 0)//找到了输出 
        {
            printf("你要查找人的数据:\n");
            printf("名字:%s\n", (*p1).name);
            printf("性别:%s\t", (*p1).wm);
            printf("手机:%s\t", (*p1).stel);
            printf("家庭住址:%s\n", (*p1).home);
            break;
        }
        p1 = (*p1).next;
    }
    if (p1 == NULL)//找完了,没找到 
        printf("您要查找的人不存在\n");
    printf("========结束查找========\n");
}
void update(stu* p1)//修改数据
{
    int n;//选择要修改的内容
    char name[20];//修改人的名字
    printf("========修改数据========\n");
    printf("请输入要修改人的姓名:");
    scanf("%s", name);
    while (p1 != NULL)
    {
        if (!strcmp(name, (*p1).name))//找到了 
        {
            printf("要修改人的数据为:\n");
            printf("名字:%s\n", (*p1).name);
            printf("性别:%s\t", (*p1).wm);
            printf("手机:%s\t", (*p1).stel);
            printf("家庭住址:%s\n", (*p1).home);
            printf("请选择要修改的信息:");
            printf("\t1.名字\t2.性别\t3.手机\t4.家庭住址\n\n您的选择是(1~4):");
            scanf("%d", &n);
            switch (n)
            {
            case 1:
                printf("名字:");
                scanf("%s", &(*p1).name);
                break;
            case 2:
                printf("性别:");
                scanf("%s", &(*p1).wm);
                break;
            case 3:
                printf("手机:");
                scanf("%s", &(*p1).stel);
                break;
            case 4:
                printf("家庭住址:");
                scanf("%s", &(*p1).home);
                break;
            }
            printf("========修改成功========\n");
            break;
        }
        p1 = (*p1).next;
    }
    if (p1 == NULL)//找完了,没有找到 
    {
        printf("没有找到该人信息\n");
        printf("========修改失败========\n");
    }
}
void save(stu* p1)//保存数据 
{
    printf("========保存数据========\n");
    FILE* fp;
    char file[15];
    printf("请输入文件名:");
    scanf("%s", file);
    if ((fp = fopen(file, "w")) == NULL)//打开文件,若没有则新建立 
    {
        printf("cannot open this file\n");//无法建立新文件 
        exit(0);//正常运行并退出程序 
    }
    while (p1 != NULL)
    {
        fprintf(fp, "%s\t", (*p1).name);
        fprintf(fp, "%s\t", (*p1).wm);
        fprintf(fp, "%s\t", (*p1).stel);
        fprintf(fp, "%s\n", (*p1).home);
        p1 = (*p1).next;
    }
    printf("========保存成功========\n");
    init();//
    fclose(fp);
}
int main(void)
{
    int n;
    init();
    screen();
    while (1)
    {
        printf("请输入你的选择(1~9):");
        scanf("%d", &n);
        if (n < 1 || n>9)
        {
            printf("输入有误!");
            break;
        }
        switch (n)
        {
        case 1:
            input();
            break;
        case 2:
            look();
            break;
        case 3:
            insert();
            break;
        case 4:
            deleted();
            break;
        case 5:
            find(head);
            break;
        case 6:
            update(head);
            break;
        case 7:
            save(head);
            break;
        case 8:
            screen();
            break;
        case 9:
            printf("===============欢迎你再次使用通讯录系统===============\n");
            exit(0);//退出系统 
            break;
        }
    }
}

这里面也没有年龄啊