zoukankan      html  css  js  c++  java
  • 1.数据结构之线性表的顺序存储

    #include <stdio.h>
    #include
    <stdlib.h>

    #define Description LinkListSquence
    #define SIZE 20

    typedef
    int type;
    typedef
    int bool;

    typedef
    struct{
    type data[SIZE];
    int length;
    }List;

    List
    * InitList(List *list);
    bool ListEmpty(List *list);
    List
    * ClearList(List *list);
    type GetElem(List
    *list,int index);
    int LocateElem(List *list,type element);
    int ListLength(List *list);

    bool ListInsert(List * list,int index,type element);
    bool ListAppend(List * list,type element);
    type ListDelete(List
    *list,int index);


    void ShiftToRight(List * list,int index);
    void ShiftToLeft(List * list,int index);

    int main(int argc, char ** argv)
    {
    List list;
    type ele ;
    InitList(
    &list);

    if(ListEmpty(&list))
    {
    printf(
    "empty\n");
    }
    ele
    = 0;
    ListAppend(
    &list,ele);
    printf(
    "length:%d\n",list.length);

    ListInsert(
    &list,list.length-1,ele+1);
    printf(
    "length:%d\n",list.length);

    return 0;
    }

    List
    * InitList(List *list)
    {
    list
    ->length = 0;
    return list;
    }

    bool ListEmpty(List *list)
    {
    if(list->length == 0)
    {
    return 1;
    }
    return 0;
    }

    bool ListFull(List * list)
    {
    return list->length == SIZE;
    }

    /*Clear the list ,so that can use the element*/
    List
    * ClearList(List *list)
    {
    list
    ->length = 0;
    return list;
    }

    /*get a element by index*/
    type GetElem(List
    *list,int index)
    {
    return list->data[index];
    }

    /*get the index of the element in the list*/
    int LocateElem(List *list,type element)
    {
    int i = list->length - 1;
    for(; i >= 0; i--)
    {
    if(list->data[i] == element)
    {
    return i;
    }
    }
    return -1;
    }

    int ListLength(List *list)
    {
    return list->length;
    }

    /*index starts with 0 to SIZE-1 */
    bool ListInsert(List * list,int index,type element)
    {
    if(list->length < SIZE && index < SIZE)
    {
    int i = list->length - 1;
    for(;i > index;i--)
    {
    ShiftToRight(list,i);
    }
    list
    ->data[index] = element;
    list
    ->length++;
    return 1;
    }

    return 0;
    }

    bool ListAppend(List * list,type element)
    {
    if(list->length < SIZE)
    {
    list
    ->data[list->length] = element;
    list
    ->length++;
    return 1;
    }

    return 0;
    }

    /*index starts with 0 to SIZE-1 */
    bool ListDelete(List *list,int index)
    {
    if(list->length < SIZE && index < SIZE)
    {
    int i = index;
    for(;i <= list->length - 1;i++)
    {
    ShiftToLeft(list,i);
    }
    list
    ->length--;

    return 1;
    }

    return 0;
    }

    void ShiftToRight(List * list,int index)
    {
    list
    ->data[index+1] = list->data[index];
    return ;
    }

    void ShiftToLeft(List * list,int index)
    {
    list
    ->data[index-1] = list->data[index];
    return ;
    }

      

  • 相关阅读:
    java运算符
    Java中的变量与常量
    java 的数据类型
    Windows Server 2012 R2上安装.Net4.6.1出错
    数据库面试基础知识整理
    C语言面试程序阅读整理
    C语言面试基础知识整理
    Android Studio工程项目打包成SDK(jar或aar格式)
    Android Studio 添加引用Module项目
    Android Studio打包SDK后,为什么没有bundles文件夹?
  • 原文地址:https://www.cnblogs.com/ToDoToTry/p/2166735.html
Copyright © 2011-2022 走看看