day19

day19_第1张图片

 主函数

#include "main.h"
int main(int argc, const char *argv[])
{
    int g = 0;
    stu s1;
    clptr C = list_create();
    if(C == NULL)
    {
        printf("申请失败\n");
        return 0;
    }
/*    while(1)
    {
        printf("请输入想要的功能:")
        scanf("%d",&g);
        switch(g)
        {
        case 1:
        }
    }*/
    list_add(C,"谢","男",20);
    list_add(C,"米","男",18);
    list_add(C,"曾","女",20);
    list_add(C,"邓","男",20);
    list_put(C);
    list_sc(C,2);
    list_put(C);
    list_xg(C,2,"陶","男",23);
    list_put(C);
    list_find(C,"陶");
    list_free(&C);
    return 0;
}

函数封装

#include "main.h"

clptr list_create()
{
    clptr C =(clptr)malloc(sizeof(cl));
    if(NULL==C)
    {
        printf("顺序表创建失败\n");
        return NULL;
    }
    memset(C->data,0,sizeof(C->data));
    C->len = 0;
    printf("创建成功\n");
    return C;
}
/************判空******/
int cl_empty(clptr C)
{
    if(NULL==C)
    {
        printf("所给顺序表不合法\n");
        return 0;
    }
    return C->len == 0;
}
/*************判满**********/
int cl_full(clptr C)
{
    if(NULL==C)
    {
        printf("所给顺序表不合法\n");
        return 0;
    }
    return C->len == MAX;
}
/***************添加************/
int list_add(clptr C,char *name,char *sex,int year)
{
    if(NULL==C||cl_full(C))
    {
        printf("添加失败\n");
        return 0;
    }
    strcpy(C->data[C->len].name,name);
    strcpy(C->data[C->len].sex,sex);
    C->data[C->len].year=year;
    C->len++;
    return 1;
}
/**************删除***************/
int list_sc(clptr C,int pos)
{
    if(NULL==C||cl_empty(C)||pos<0||pos>C->len)
    {
        printf("删除失败\n");
        return 0;
    }
    printf("删除后\n");
    for(int i=pos+1;ilen;i++)
    {
        C->data[i-1]=C->data[i];
    }
    C->len--;
}
/***************修改***************/
int list_xg(clptr C,int pos,char *name,char *sex,int year)
{
    if(NULL==C||cl_empty(C)||pos<0||pos>C->len)
    {
        printf("修改失败\n");
        return 0;
    }
    printf("修改后\n");
    strcpy(C->data[pos].name,name);
    strcpy(C->data[pos].sex,sex);
    C->data[pos].year=year;
}
/****************查找**************/
void list_find(clptr C,char *name)
{
    if(NULL==C||cl_empty(C))
    {
        printf("查找失败\n");
    }
    for(int i=0;ilen;i++)
    {
        if(strcmp(C->data[i].name,name)==0)
        {
            printf("查找成功\n");
            printf("姓名\t性别\t年龄\n");
            printf("%s\t%s\t%d\n",C->data[i].name,C->data[i].sex,C->data[i].year);
        }
    }
}
/******************输出************/
void list_put(clptr C)
{
    if(NULL==C||cl_empty(C))
    {
        printf("输出失败\n");
    }
    printf("姓名\t性别\t年龄\n");
    for(int i=0;ilen;i++)
    {
        printf("%s\t%s\t%d\n",C->data[i].name,C->data[i].sex,C->data[i].year);
    }
}
/************释放************/
void list_free(clptr *C)
{
    if(NULL!=*C)
    {
        free(*C);
        *C=NULL;
    }
    printf("释放成功\n");
}

头函数

#ifndef _MAIN_H_
#define _MAIN_H_
#include
#include
#include
#define MAX 20
typedef struct 
{
    char name[20];
    char sex[20];
    int  year;
}stu,*stuptr;

typedef struct
{
    stu data[MAX];
    int len;
}cl,*clptr;

//申请
clptr list_create();
//判空
int cl_empty(clptr C);
//判满
int cl_full(clptr C);
//添加
int list_add(clptr C,char *name,char *sex,int year);
//删除
int list_sc(clptr C,int pos);
//输出
void list_put(clptr C);
//修改
int list_xg(clptr C,int pos,char *name,char *sex,int year);
//查找
void list_find(clptr C,char *name);
//释放
void list_free(clptr *C);
#endif


day19_第2张图片

 

你可能感兴趣的:(数据结构)