数据结构 实验 学生通讯录项目

数据结构

实验 学生通讯录项目  

一、学生通讯录项目的问题分析

1.寻找出常见通讯录解决的问题所在,确认问题;

建立一个通讯录系统,使其能够存储联系人的信息(姓名,学号,手机号),并可以分别通过姓名或学号查找到其具体信息,对进行删除和修改,对所有联系人进行排序以及添加学生信息等功能。帮助有需要的人进行更快的分析与操作

2.分解问题,写出问题陈述,即把问题分解为各个比较小的问题,区分出紧急、严重性或可能性等问题

1.创建通讯录
  2.显示通讯录
  3.按姓名,学号分别查询通讯录
  4.按姓名,学号分别修改通讯录
  5.按姓名,学号分别删除通讯录
  6.按姓名,学号分别升序,排序通讯录
  7.添加学生信息

3. 分析选择关键活动,按照问题优先度排序,即制订研究这些问题的先后程序。

先规划出来所需要的功能,在进行结构体定义,将功能函数定义出来,最后写主函数,将功能函数放在其中。

4. 分析此类问题所需数据的类型、特点、关系等。

使用数组,将内容存放在数组中。

二、学生通讯录项目的结构设计

思考:手机通讯录中联系人信息存放的特点有哪些?

1.根据问题分析设计一款合适的数据结构

2.选择合适存储结构方案,写出具体的结构体定义

typedef struct telephone{
    char name[25];
    char num[25];
    char tel[25];
}TEL;

3.设计通讯录的基本功能/操作

输入通讯录里学生的个数、学生的姓名、学号、电话号码后,可进行以下功能操作:
1.显示通讯录。显示通讯录里学生的姓名、学号、电话号码,由DisplayList()函数实现。
2. 查询通讯录。可以按照两种方式查询,一种是按姓名查询,另一种是按学号查询,分别由InquireListName()和InquireListNum()函数实现。
3. 修改通讯录。可以按照两种方式修改,一种是按姓名修改,另一种是按学号修改,分别由ChangeListName()和ChangeListNum()函数实现。
4. 删除通讯录。可以按照两种方式删除,一种是按姓名删除,另一种是按学号删除,分别由DelListName()和DelListNum()函数实现。
5. 排序通讯录。可以按照两种方式排序,一种是按姓名升序排序,另一种是按学号逆序排序,分别由UpSortListName ()和DownSortListNum ()函数实现。
6.添加学生信息。添加学生的学号、姓名、电话号码,由AddList()函数实现。

三、代码

#include <stdio.h>
#include <string.h>
#define N 108
typedef struct telephone{
    char name[25];
    char num[25];
    char tel[25];
}TEL;
 
void DisplayMenu(); //显示主菜单
void save(TEL a[], int n);
void CreateList(TEL a[], int n);      //1.创建通讯录
void DisplayList(TEL a[], int n);     //2.显示通讯录
void InquireListName(TEL a[], int n); //3.按姓名查询通讯录
void InquireListNum(TEL a[], int n);  //4.按学号查询通讯录
void ChangeListName(TEL a[], int n);  //5.按姓名修改通讯录
void ChangeListNum(TEL a[], int n);   //6.按学号修改通讯录
int DelListName(TEL a[], int n);      //7.按姓名删除通讯录
int DelListNum(TEL a[], int n);       //8.按学号删除通讯录
void UpSortListName(TEL a[], int n);  //9.姓名升序排序通讯录
void DownSortListNum(TEL a[], int n); //10.学号逆序排序通讯录
int AddList(TEL a[], int n);          //11.添加学生信息
 
int main()
{
    struct telephone a[N];
    int i, n;
    FILE *fp;

       {
		printf("使用该系统,请输入n和n个姓名、学号、电话号码:\n");
        scanf("%d", &n);
        for (i = 0; i < n; i++)
            scanf("%s%s%s", a[i].name, a[i].num, a[i].tel);
        save(a, n);
    }
 
    DisplayMenu(); //显示主菜单
    while (1)
    {
        char select;
        char name[25];
        scanf(" %c", &select);
 
        if (select < 'a' || select > 'l')
        {
            printf("输入错误!\n");
            continue;
        }
        //if( select=='l' )
        //    break;
 
        switch (select)
        {
        case 'a':
            DisplayMenu(); //显示主菜单
            break;
        case 'b':
            DisplayList(a, n); //2.显示通讯录
            break;
        case 'c':
            InquireListName(a, n); //3.按姓名查询通讯录
            break;
        case 'd':
            InquireListNum(a, n); //4.按学号查询通讯录
            break;
        case 'e':
            ChangeListName(a, n); //5.按姓名修改通讯录
            break;
        case 'f':
            ChangeListNum(a, n); //6.按学号修改通讯录
            break;
        case 'g':
            if (DelListName(a, n)) //7.按姓名删除通讯录
                n--;
            break;
        case 'h':
            if (DelListNum(a, n)) //8.按学号删除通讯录
                n--;
            break;
        case 'i':
            UpSortListName(a, n); //9.姓名升序排序通讯录
            break;
        case 'j':
            DownSortListNum(a, n); //10.学号逆序排序通讯录
            break;
        case 'k':
            if (AddList(a, n)) //11.添加学生信息
                n++;
            save(a, n);
            break;
        case 'l':
           // exit(0); //12.退出系统
            break;
        }
    }
    return 0;
}
 
void save(TEL a[], int n)
{
    int i;
    FILE *fp;
    fp = fopen("stu.dat", "w");
    fprintf(fp, "%d\n", n);
    for (i = 0; i < n; i++)
        fprintf(fp, "%s\t%s\t%s\n", a[i].name, a[i].num, a[i].tel);
}
 
void DisplayMenu() //1.显示主菜单

 {
    printf("                      学生通讯录管理系统\n\n");
    printf("*************************系统功能菜单**************************\n");
    printf(" -------------------------------------------------------------\n");
    printf("**********************a.显示主菜单 ***************************\n");
    printf("**********************b.显示通讯录****************************\n");
    printf("**********************c.按姓名查询通讯录**********************\n");
    printf("**********************d.按学号查询通讯录**********************\n");
    printf("**********************e.按姓名修改通讯录**********************\n");
    printf("**********************f.按学号修改通讯录**********************\n");
    printf("**********************g.按姓名删除通讯录**********************\n");
    printf("**********************h.按学号删除通讯录**********************\n");
    printf("**********************i.姓名升序排序通讯录********************\n");
    printf("**********************j.学号逆序排序通讯录********************\n");
    printf("**********************k.添加学生信息*************************\n");
    printf("**********************l.退出系统*****************************\n");
    printf(" -------------------------------------------------------------\n");
    printf("***************************************************************\n\n");
    printf("请选择您需要的操作:\n");
}
void DisplayList(TEL a[], int n) //2.显示通讯录
{
    int i;
    printf("显示通讯录:\n");
    for (i = 0; i < n; i++)
        printf("%s\t%s\t%s\n", a[i].name, a[i].num, a[i].tel);
    printf("\n");
}
void InquireListName(TEL a[], int n) //3.按姓名查询通讯录
{
    int i, flag;
    char SearchName[25];
    printf("按姓名查询通讯录:\n");
    scanf("%s", SearchName);
    for (i = 0, flag = 0; i < n; i++)
    {
        if (strcmp(SearchName, a[i].name) == 0)
        {
            printf("%s\t", a[i].name);
            printf("%s\t", a[i].num);
            printf("%s\n", a[i].tel);
            flag = 1;
            break;
        }
    }
    if (flag == 0)
    {
        printf("未查询到该姓名信息!\n");
    }
    printf("\n");
}
 
void InquireListNum(TEL a[], int n) //4.按学号查询通讯录
{
    int i, flag;
    char SearchID[25];
    printf("按学号查询通讯录:\n");
    scanf("%s", SearchID);
    for (i = 0, flag = 0; i < n; i++)
    {
        if (strcmp(SearchID, a[i].num) == 0)
        {
            printf("%s\t", a[i].name);
            printf("%s\t", a[i].num);
            printf("%s\n", a[i].tel);
            flag = 1;
            break;
        }
    }
    if (flag == 0)
    {
        printf("未查询到该学号信息!\n");
    }
    printf("\n");
}
void ChangeListName(TEL a[], int n) //5.按姓名修改通讯录
{
    int i, flag;
    char SearchName[25];
    printf("按姓名修改通讯录:\n");
    scanf("%s", SearchName);
    for (i = 0, flag = 0; i < n; i++)
    {
        if (strcmp(SearchName, a[i].name) == 0)
        {
            strcpy(a[i].name, SearchName);
            printf("请输入要修改的学号:");
            scanf("%s", a[i].num);
            printf("请输入要修改的电话号码:");
            scanf("%s", a[i].tel);
            //strcpy(p[i].name,ChangeName);
            //strcpy(p[i].name,ChangeTel);
            save(a, n);
            printf("信息修改完毕!\n");
            printf("%s\t%s\t%s\n", a[i].name, a[i].num, a[i].tel);
            flag = 1;
            break;
        }
    }
    if (flag == 0)
        printf("未找到该姓名信息!");
    printf("\n");
}
 
void ChangeListNum(TEL a[], int n) //6.按学号修改通讯录
{
    int i, flag;
    char SearchNum[25];
    printf("按学号修改通讯录:\n");
    scanf("%s", SearchNum);
    for (i = 0, flag = 0; i < n; i++)
    {
        if (strcmp(SearchNum, a[i].num) == 0)
        {
            strcpy(a[i].num, SearchNum);
            printf("请输入要修改的名字:");
            scanf("%s", a[i].name);
            printf("请输入要修改的电话号码:");
            scanf("%s", a[i].tel);
            //strcpy(p[i].name,ChangeName);
            //strcpy(p[i].name,ChangeTel);
            save(a, n);
            printf("信息修改完毕!\n");
            printf("%s\t%s\t%s\n", a[i].name, a[i].num, a[i].tel);
            flag = 1;
            break;
        }
    }
    if (flag == 0)
        printf("未找到该学号信息!");
    printf("\n");
}
 
int DelListName(TEL a[], int n) //7.按姓名删除通讯录
{
    int i, j;
    char SearchName[25];
    printf("按姓名删除通讯录:\n");
    scanf("%s", SearchName);
    for (i = 0; i < n; i++)
    {
        if (strcmp(a[i].name, SearchName) == 0)
            break;
    }
    if (i >= n)
    {
        printf("未查询到该姓名信息!按姓名删除通讯录失败!\n");
        return 0;
    }
    else
    {
        for (j = i; j < n - 1; j++)
            a[j] = a[j + 1];
        save(a, n);
        printf("按姓名删除通讯录成功!\n");
        return 1;
    }
}
 
int DelListNum(TEL a[], int n) //8.按学号删除通讯录
{
    int i, j, flag;
    char SearchNum[25];
    printf("按学号删除通讯录:\n");
    scanf("%s", SearchNum);
    for (i = 0; i < n; i++)
    {
        if (strcmp(a[i].num, SearchNum) == 0)
            break;
    }
    if (i >= n)
    {
	        printf("未查询到该学号信息!按学号删除通讯录失败!\n");
        return 0;
    }
    else
    {
        for (j = i; j < n - 1; j++)
            a[j] = a[j + 1];
        printf("按学号删除通讯录成功!\n");
        save(a, n);
        return 1;
    }
    printf("\n");
}
 
void UpSortListName(TEL a[], int n) //9.姓名升序排序通讯录
{
    int i, j;
    TEL temp;
    for (i = 0; i < n; i++)
    {
        for (j = i + 1; j < n; j++)
        {
            if (strcmp(a[i].name, a[j].name) > 0)
            {
                temp = a[i];
                a[i] = a[j];
                a[j] = temp;
            }
        }
    }
    printf("姓名升序排序通讯录:\n");
    for (i = 0; i < n; i++)
        printf("%s\t%s\t%s\n", a[i].name, a[i].num, a[i].tel);
    printf("\n");
}
 
void DownSortListNum(TEL a[], int n) //10.学号逆序排序通讯录
{
    int i, j;
    TEL temp;
    for (i = 0; i < n; i++)
    {
        for (j = i + 1; j < n; j++)
        {
            if (strcmp(a[i].num, a[j].num) > 0)
            {
                temp = a[i];
                a[i] = a[j];
                a[j] = temp;
            }
        }
    }
    printf("学号逆序排序通讯录:\n");
    for (i = n - 1; i >= 0; i--)
        printf("%s\t%s\t%s\n", a[i].name, a[i].num, a[i].tel);
    printf("\n");
}
 
int AddList(TEL a[], int n) //11.添加学生信息
{
    int i, flag;
    char AddNum[25];
    printf("添加通讯录:\n");
    printf("请输入要添加的学号:");
    scanf("%s", AddNum);
    for (i = 0, flag = 0; i < n; i++)
    {
        if (strcmp(AddNum, a[i].num) == 0)
        {
            flag = 1;
            printf("学号重复!\n");
            return 0;
        }
    }
    if (flag == 0)
    {
        //n++;
        printf("学号不重复!请添加信息:\n");
        printf("请输入要添加的名字:");
        scanf("%s", a[n].name);
        strcpy(a[n].num, AddNum);
        printf("请输入要添加的电话号码:");
        scanf("%s", a[n].tel);
        //save(a,n);
        printf("添加信息成功!\n");
        return 1;
        //printf("%d",n);
    }
    printf("\n");
}

四、实验结果

3.根据各测试数据运行学生通讯录并截图。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值