1、结构体数组的输入查询删除查询输出

#include<stdio.h>
#include<malloc.h>
#include<stdlib.h>
#include<string.h>
#define ERROR -1
#define OK 0
#define MAXNUM 100

typedef struct{
    char *name;
}Student;
typedef struct{
    Student cls[MAXNUM];
    int length;
}SqList;
void InitSqList(SqList *&L)
{
    L = (SqList*)malloc(sizeof(SqList));
    L->length = 0;
}

int Inputname(Student*&S,SqList*&L)
{
    int n=0;
    char ch=0;
    printf("请输入班级人名:\n");
    while (1)
    {
        L->cls[n].name = (char*)malloc(sizeof(char));
        if (scanf("%s",L->cls[n].name))
        {
            n++;
            L->length++;
        }
        ch = getchar();
        if (ch == '\n')
            break;
    }
    return OK;
}
int InsertSqList(SqList*L, int n, char *a)
{
    int k;
    if (n < 0 || n > L->length + 1)
        return ERROR;
    else
        for (k = L->length + 1; k >= n; k--){
            L->cls[k] = L->cls[k - 1];
        }
    L->cls[n - 1].name = a;
    L->length++;
    return OK;
}
int DeleteSqList(SqList*L, int n)
{
    int k;
    if (n <= 0 || n > L->length)
        return ERROR;
    else
        for (k = n; k < L->length; k++)
        {
            L->cls[k - 1] = L->cls[k];
        }
    L->length--;
    return OK;
}
bool ListEmpty(SqList *L)
{
    return (L->length == 0);
}
int Lookup(SqList*L, char *b)
{
    int k;
    int i = 0;
    while (i < L->length&&(strcmp(L->cls[i].name,b)!= 0))
    {
        i++;
        k = i;
    }
    if (i>=L->length)
        printf("未找到该名字\n");
    else
        printf("%s在第%d个位置\n", b,k+1);
    return OK;
}//

int DispSqList(SqList*L)
{
    int i;
    if (ListEmpty(L))
        return ERROR;
    printf("输出的班级人名为:\n");
    for (i = 0; i < L->length; i++){
        printf("%s", L->cls[i].name);
        printf("\n");
    }
    return OK;
}
void main()
{
    SqList*L;
    Student*S;
    InitSqList(L);
    char temp;
    int i;
    i = 0;
    temp = '0';
    while (1)
    {
        if (temp == '0' || temp == '1' || temp == '2' || temp == '3' || temp == '4')
        {
            printf("---------Menu is as following--------\n");
            printf(" press 1 return to input name from name.txt\n");
            printf(" press 2 return to insert name\n");
            printf(" press 3 return to lookup name \n");
            printf(" press 4 return to print all name \n");
            printf(" press q to quit\n");
        }

        temp = getchar();//从键盘上输入一个数字后回车,getchar会返回两次,一次是数字,一次是'\n',所以要做上面的处理。

        switch (temp)
        {
        case '1':
            Inputname(S,L);
            break;
        case '2':
            printf("请输入想要插入的位置和姓名:\n");
            int n;
            char *a;
            a = (char*)malloc(sizeof(char));
            scanf("%d %s", &n,a);
            InsertSqList(L, n, a);
            break;
        case '3':
            printf("请输入你想要查询的姓名:\n");
            char *b;
            b= (char*)malloc(sizeof(char));
            scanf("%s",b);
            Lookup(L,b);
            break;
        case '4':
            DispSqList(L);
            break;
        case 'q':
            return;
        default:
            break;
        }

    }
    return;
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 好的,我可以为您提供一些关于C语言结构体数组学生信息管理的建议。首先,您需要定义一个结构体来表示学生的信息,例如: ```c struct student { char name[20]; int age; char gender[10]; float score; }; ``` 然后,您需要定义一个结构体数组来存储多个学生的信息,例如: ```c struct student stu[100]; ``` 接下来,您可以编写一些函数来实现学生信息的管理,例如: - 添加学生信息: ```c void add_student() { // 读取学生信息 printf("请输入学生姓名:"); scanf("%s", stu[count].name); printf("请输入学生年龄:"); scanf("%d", &stu[count].age); printf("请输入学生性别:"); scanf("%s", stu[count].gender); printf("请输入学生成绩:"); scanf("%f", &stu[count].score); // 更新学生数量 count++; } ``` - 显示所有学生信息: ```c void show_students() { // 遍历所有学生 for (int i = 0; i < count; i++) { // 打印学生信息 printf("姓名:%s,年龄:%d,性别:%s,成绩:%.2f\n", stu[i].name, stu[i].age, stu[i].gender, stu[i].score); } } ``` - 查找学生信息: ```c void find_student() { // 读取学生姓名 char name[20]; printf("请输入要查找的学生姓名:"); scanf("%s", name); // 遍历所有学生 for (int i = 0; i < count; i++) { // 比较学生姓名 if (strcmp(stu[i].name, name) == 0) { // 打印学生信息 printf("姓名:%s,年龄:%d,性别:%s,成绩:%.2f\n", stu[i].name, stu[i].age, stu[i].gender, stu[i].score); return; } } // 如果找不到该学生,则打印提示信息 printf("找不到该学生!\n"); } ``` 希望这些代码可以帮助您实现C语言结构体数组学生信息管理。 ### 回答2: C语言结构体数组学生信息管理是一种用来管理学生信息的数据结构。结构体是一种自定义的数据类型,可以包含多个不同的数据类型,用于表示一个学生的相关信息。 使用结构体数组,我们可以方便地存储和管理多个学生的信息。首先,我们需要定义一个结构体来表示学生信息,比如包含学号、姓名、年龄等字段。然后,可以创建一个结构体数组,用来存储多个学生的信息。 以下是一个简单的示例: ``` #include <stdio.h> // 定义学生信息结构体 struct Student { int rollNumber; char name[50]; int age; }; // 主函数 int main() { // 创建一个包含3个学生信息的结构体数组 struct Student students[3]; // 为每个学生输入信息 for (int i = 0; i < 3; i++) { printf("请输入第%d个学生的学号:", i + 1); scanf("%d", &students[i].rollNumber); printf("请输入第%d个学生的姓名:", i + 1); scanf("%s", students[i].name); printf("请输入第%d个学生的年龄:", i + 1); scanf("%d", &students[i].age); } // 打印所有学生的信息 for (int i = 0; i < 3; i++) { printf("第%d个学生的学号:%d\n", i + 1, students[i].rollNumber); printf("第%d个学生的姓名:%s\n", i + 1, students[i].name); printf("第%d个学生的年龄:%d\n", i + 1, students[i].age); printf("\n"); } return 0; } ``` 以上示例中,我们定义了一个学生信息结构体`struct Student`,包含学号、姓名和年龄字段。然后,创建了一个包含3个学生信息的结构体数组`students`。通过循环,将每个学生的信息输入结构体数组中,然后再通过循环打印出所有学生的信息。 这种方式可以方便地存储和管理多个学生的信息,对学生信息的增加、查询、修改和删除操作都可以通过结构体数组实现。 ### 回答3: C语言结构体数组可以用来实现学生信息管理系统。首先,我们可以定义一个结构体类型,其中包含学生的姓名、年龄、性别和学号等信息。然后,我们可以创建一个结构体数组,来存储多个学生的信息。 例如,我们可以定义一个名为Student的结构体类型,其中包含姓名、年龄、性别和学号四个成员变量: ```c struct Student { char name[20]; int age; char gender[10]; int id; }; ``` 然后,我们可以声明一个结构体数组来存储多个学生的信息: ```c struct Student students[100]; ``` 这样,我们就可以使用这个数组来管理多个学生的信息了。例如,我们可以通过下标来访问某个学生的具体信息: ```c students[0].id = 1001; strcpy(students[0].name, "张三"); students[0].age = 18; strcpy(students[0].gender, "男"); ``` 我们也可以使用循环遍历数组,输出所有学生的信息: ```c for (int i = 0; i < 100; i++) { printf("学生%d的姓名:%s\n", i+1, students[i].name); printf("学生%d的年龄:%d\n", i+1, students[i].age); printf("学生%d的性别:%s\n", i+1, students[i].gender); printf("学生%d的学号:%d\n", i+1, students[i].id); } ``` 通过使用结构体数组,我们可以方便地管理学生的信息,进行增加、删除、修改和查找等操作,实现一个简单的学生信息管理系统。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值