线性表的顺序表示和实现(C语言)

最近开始准备软件设计师考试,所以把数据结构的知识梳理一遍。

首先线性表的顺序表示。


//list.c
#include<stdio.h>
#include<stdlib.h>
#define ERROR   -1
#define OVERFLOW 2
#define TRUE    1
#define FALSE   0
#define OK 1
#define LIST_INIT_SIZE  100
#define LIST_INCREMENT  10
typedef struct{
    int * elem;
    int length;
    int listsize;
}sq_list;      
int init_list_sq(sq_list *sl);
void destroy_list_sq(sq_list * sl);
int clear_list(sq_list * sl);
int list_empty(sq_list sl);
int list_length(sq_list sl);
void get_elem(sq_list sl, int index, int * elem);
int locate_elem(sq_list sl, int elem);
int prior_elem(sq_list sl, int curelem, int *priorelem);
int next_elem(sq_list sl, int curelem, int *nextelem);
int insert_elem(sq_list *sl, int  index, int elem);
int list_delete_elem(sq_list * sl, int index, int * elem);
int visit_all(sq_list sl);
int init_list_sq(sq_list *sl)
{
    sl->elem = (int*)malloc(LIST_INIT_SIZE * sizeof(int));
    if(!sl->elem)   
        exit(OVERFLOW);
    sl->length = 0;
    sl->listsize = LIST_INIT_SIZE;
    return OK;
}
void destroy_list_sq(sq_list * sl)
{
    free(sl->elem);
}
int clear_list(sq_list * sl)
{
    destroy_list_sq(sl);
    init_list_sq(sl);
    return OK;
}
int list_empty(sq_list sl)
{
    if(sl.length)
        return FALSE;
    else
        return TRUE;
}
int list_length(sq_list sl)
{
    return sl.length;
}
void get_elem(sq_list sl, int index, int * e)
{
    *e = sl.elem[index-1];
}
int locate_elem(sq_list sl, int e)
{
    int len;
    for (len = 1; len <= sl.length; len++)
        if(sl.elem[len-1] == e)
            return len;
    return ERROR;
}
int insert_elem(sq_list *sl, int index, int e)
{
    int * insert_ptr, * temp_ptr;
    if(index < 1 || index > sl->length + 1)
        return ERROR;
    if(sl->length >= sl->listsize)
    {
        sl->elem = (int *)realloc(sl->elem, (sl->listsize + LIST_INCREMENT) * sizeof(int) );
        if(!sl->elem)
            exit(OVERFLOW);
        sl->listsize += LIST_INCREMENT;
    }
                                                 
    insert_ptr = &(sl->elem[index-1]);
                                                 
    for ( temp_ptr = &(sl->elem[sl->length-1]); temp_ptr >= insert_ptr; temp_ptr--)
        *(temp_ptr+1) = *temp_ptr;
    * insert_ptr = e;
    sl->length++;
    return OK;
}
int list_delete_elem(sq_list * sl, int index, int * e)
{  
    int * end_ptr, * temp_ptr;
    if(index < 1|| index > sl->length)
        return ERROR;
    end_ptr = &(sl->elem[sl->length-1]);
    temp_ptr = &(sl->elem[index-1]);
    *e = *temp_ptr;
    for (; temp_ptr < end_ptr; temp_ptr++ )
    {
        *temp_ptr = *(temp_ptr+1);
    }
    sl->length--;
    return OK;
}
int prior_elem(sq_list sl, int curelem, int *priorelem)
{
    int * temp_ptr;
    if( (sl.elem[0]) == curelem)
        return ERROR;
    temp_ptr = sl.elem;
    for(++temp_ptr; temp_ptr < sl.elem+sl.length; temp_ptr++)
    {
        if(*temp_ptr == curelem )
        {
            *priorelem = *(temp_ptr-1);
            return OK;
        }
    }
    return ERROR;  
}
int next_elem(sq_list sl, int curelem, int *nextelem)
{
    int * temp_ptr;
    if( (sl.elem[sl.length-1]) == curelem)
        return ERROR;
    temp_ptr = sl.elem;
    for(; temp_ptr < sl.elem+sl.length-1; temp_ptr++)
    {
        if(*temp_ptr == curelem)
        {
            *nextelem = *(temp_ptr+1);
            return OK;
        }
    }
    return ERROR;
}
int visit_all(sq_list sl)
{
    int *temp_ptr;
    temp_ptr = sl.elem;
    for(; temp_ptr<= sl.elem+sl.length-1; temp_ptr++)
        printf("%5d", *temp_ptr);
    return OK;
}

下面是主函数

//main.c
#include"list.c"
#include"prompt.c"
int main()
{
    sq_list sl;
    int elem, pos, elem1;
    int op;
    while((op = prompt()) >= 0 && op <= 9 )
    {
        switch(op){
        case 0 :
            if (init_list_sq(&sl) == OK)
                printf("A table has beend created.\n");
            break;
        case 1 :
            printf("Enter an element and position:");
            scanf("%d %d", &elem, &pos);
            if(insert_elem(&sl, pos, elem) == OK)
                printf("Insertion succeed!\n");
            break;
        case 2 :
            printf("Enter deleteted position:");
            scanf("%d", &pos);
            if(list_delete_elem(&sl, pos, &elem) == OK)
                printf("Delete succeed!\n");
            break;
        case 3 :
            printf("Enter an element's position:");
            scanf("%d", &pos);
            get_elem(sl, pos, &elem1);
                printf("get elemnet:%d\n", elem1);
            break;
        case 4 :
            printf("Enter an element :");
            scanf("%d", &elem);
            if (prior_elem(sl, elem, &elem1) == OK)
                printf("%d's prior element:%d\n", elem, elem1);
            break;
        case 5 :
            printf("Enter an element :");
            scanf("%d", &elem);
            if (next_elem(sl, elem, &elem1) == OK)
                printf("%d's next element:%d\n", elem, elem1);
            break;
        case 6 :
            printf("length:%d\n", list_length(sl));
            break;
        case 7 :
            printf("Enter an element:");
            scanf("%d", &elem);
            printf("position:%d\n", locate_elem(sl,elem) );
            break;
        case 8 :
            destroy_list_sq(&sl);
            printf("The table has been destroyed!\n");
            break;
        case 9 :
            if(list_empty(sl) == TRUE)
                printf("The table is blank!\n");
            else
                printf("The table is not blank!\n");
            break;
        case 'x' :
            return 0;
        default :
            printf("Enter a number (0-9)\n");
            break;
        }
    }
                         
                         
    return 0;
}

还有提示操作选项的

//prompt.c
int prompt()
{
    int option;
    printf("\n\n ********The Sequential Table********\n");
    printf(" 0. Create an new  senquential table.\n");
    printf(" 1. Insert an element into the table.\n");
    printf(" 2. Delete an element from the table.\n");
    printf(" 3. Get an specific element from the table.\n");
    printf(" 4. Get an specific element's prior element.\n");
    printf(" 5. Get an specific element's next element.\n");
    printf(" 6. Get the table's length.\n");
    printf(" 7. Locate an specific elemnet.\n");
    printf(" 8. Destory the table.\n");
    printf(" 9. Whether if the table is empty?\n");
    printf(" x. Exit\n");
    printf("Enter your option: ");
    scanf("%d", &option);
    return option;
}

Makefile文件

#makefile
main: main.o
    cc -o $@ $^
main.o: main.c
clean:
    rm main.o list.o prompt.o
                

心得体会:

基础很重要,还要注意细节。哈哈

你可能感兴趣的:(C语言,线性表)