用顺序表保存学生信息

定义一个顺序表保存学生信息,学生结构体如下:

typedef struct { char name[20]; int age; int score; }student; 实现功能:

  1. 创建一个空表

  2. 依次插入3个学生的信息

  3. 打印所有学生信息

  4. 删除位置1的学生

  5. 打印所有学生信息

 

#include <stdio.h>
#define maxNumderOfStudent 50//最大学生人数
//结构体表示学生信息
typedef struct
{
    char name[20];
    int age;
    int score;
}Stu_t;
//顺序表的结构体类型
typedef struct
{
    Stu_t student[maxNumderOfStudent];
    int size;
}List_t;

//函数声明
List_t createEmptyList();
int isEmptyList(List_t *p);
int isFullList(List_t *p);
void clearList(List_t *p);
int listLength(List_t *p);
int insertList(List_t *p,int pos,Stu_t x);
int deleteList(List_t *p,int pos);
void printList(List_t *p);


int main()
{
    List_t list=createEmptyList();
    Stu_t x={"xiaoming",22,88};
    Stu_t x={"xiaoli",24,98};
    Stu_t x={"xiaowang",2,78};
    insertList(&list,0,x);

    return 0;
}
//创建一个空顺序表
List_t createEmptyList()
{
    List_t list;
    list.size=0;
    return list;
}
//判断顺序表是否为空,返回值为1表示顺序表为空
int isEmptyList(List_t *p)
{
    return p->size==0;
}
//检查顺序表是否满,返回值为1表示顺序表为满
int isFullList(List_t *p)
{
    return p->size==maxNumderOfStudent;
}
//清理顺序表
void clearList(List_t *p)
{
    p->size=0;
}
//
int listLength(List_t *p)
{
    return p->size;
}

int insertList(List_t *p,int pos,Stu_t x)
{
    if(isFullList(p) || pos>p->size || pos<0)
    {
        return -1;
    }
    int i;
    for(i=p->size;i>pos;i--)
    {
        p->student[i]=p->student[i-1];
    }
    p->student[pos];
    p->size++;
    return 0;
}

int deleteList(List_t *p,int pos)
{
    if(isEmptyList(p) || pos>p->size || pos<0)
    {
        return -1;
    }
    int i;
    for(i=pos;i<p->size-1;i++)
    {
        p->student[i]=p->student[i+1];
    }
    p->size--;
    return 0;
}

void printList(List_t *p)
{
    int i;
    for(i=0;i<p->size;i++)
    {
        printf("%s %d %d\n",p->student[i].name,p->student[i].age,p->student[i].score);
    }
}

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值