线性表是从数据元素的逻辑结构上定义的.

这种数据元素的逻辑结构的特征如下:

1.除开第一个和最后一个元素之外.所有元素都有一个前驱元素和后继元素.

2.第一个元素无前驱元素,但有后继元素.

3.最后一个元素有前驱元素,单无后继元素.

可以抽象为如下表述:

元素1 元素2 元素3 元素4 元素5 元素6

然而同一种逻辑结构在内存中却可以有两种存储方式:1.在内存中连续存储的线性表-----顺序表(如数组)

                                 2.在内存中离散存储的线性表-----链表(如单链表,双链表)

对于顺序表有多重操作:初始化,赋值,插入新值,删除值等

下面的用C代码实现顺序表及其一些常用的操作:

 #include<stdio.h>

 #define ERROR 0

 #define InitSize 20 //顺序表的初始大小

 typedef int ElemType;

 typedef struct{
ElemType data[InitSize];
int length;
}sqlist; //顺序表初始化
void InitList(sqlist *L)
{
L->length=;
return ;
} //获取顺序表的长度
int GetLength(sqlist *L)
{
return L->length;
} //顺序表赋值
void GiveValue(sqlist *L)
{
int value;
int i=;
while(value!=)
{
printf("Please input %d valueL-------(exit until value equal 0)\n",i+);
scanf("%d",&value);
if(value!=)
{
L->data[i++]=value;
L->length++;
}
}
} //获取顺序表某个位置的值
ElemType GetValue(sqlist *L,int i)
{
ElemType e;
if(i>L->length||i<)
return ERROR; int k=;
for(k=;k<L->length;k++)
{
if(k==i-)
e=L->data[k];
}
return e;
} //获取顺序表某个值的位置
int GetPos(sqlist *L,ElemType value)
{
int pos;
int judeflag=;
int i;
for(i=;i<L->length;i++)
{
if(L->data[i]==value)
{
pos=i+;
break;
}
judeflag++;
} if(judeflag>=L->length)
return ERROR; return pos;
} //在顺序表指定位置插入新的值
void InsertValue(sqlist *L,int pos,ElemType value)
{
if(pos<||pos>L->length)
return ERROR; int i;
for(i=L->length-;i>pos-;i--)
{
L->data[i+]=L->data[i];
} L->data[pos]=value;
L->length++;
} //在顺序表中指定位置删除值
void DeleteValue(sqlist *L,int pos)
{
if(pos<||pos>L->length)
return ERROR; int i;
for(i=pos;i<L->length;i++)
{
L->data[i-]=L->data[i];
} L->length--;
} //显示顺序表
void ShowList(sqlist *L)
{
int i;
printf("The List show below:\n");
for(i=;i<L->length;i++)
{
printf("%d ",L->data[i]);
}
} //主函数
int main()
{
sqlist L;
InitList(&L);//初始化顺序表
GiveValue(&L);//顺序表赋值
ShowList(&L);//显示线性表 printf("\n\n\n\n");
int flag;
printf("******************************************************\n");
printf("*************choose the operation of List*************\n");
printf("*****************1-指定位置插入值*********************\n");
printf("*****************2-指定位置删除值*********************\n");
printf("*****************3-获取顺序表某个值得位置*************\n");
printf("*****************4-获取顺序表某个位置上的值*********\n");
printf("*****************5-获取顺序表长度*********************\n");
printf("*****************0-退出*******************************\n");
printf("******************************************************\n");
printf("\n\n\n"); printf("Input the value Flag:\n");
scanf("%d",&flag); printf("flag=%d\n",flag); int pos,value,len;
switch(flag){
case :
{
printf("Please input the value and position:\n");
scanf("%d %d",&value,&pos);
printf("Insert value=%d in pos=%d\n",value,pos+);
InsertValue(&L,pos,value);
ShowList(&L);
break;
}
case :
{
printf("Please input the position:\n");
scanf("%d",&pos);
printf("Delete value in pos=%d\n",pos);
DeleteValue(&L,pos);
ShowList(&L);
break;
}
case :
{
printf("Please input the value:\n");
scanf("%d",&value);
pos=GetPos(&L,value);
printf("Get value=%d's position is %d\n",value,pos);
ShowList(&L);
break;
}
case :
{
printf("Please input the position:\n");
scanf("%d",&pos);
value=GetValue(&L,pos);
printf("Get value=%d from pos=%d\n",value,pos);
ShowList(&L);
break;
}
case :
{
len=GetLength(&L);
printf("the length of List is %d\n",len);
ShowList(&L);
break;
}
case :
printf("you choose to exit\nGoodbye!\n");
} return ;
}

结果图:

线性表之顺序表(C语言实现)的更多相关文章

  1. [C++]数据结构:线性表之顺序表

    1 顺序表 ADT + Status InitList(SeqList &L) 初始化顺序表 + void printList(SeqList L) 遍历顺序表 + int ListLengt ...

  2. C#线性表之顺序表

    线性表是最简单.最基本.最常用的数据结构.线性表是线性结构的抽象(Abstract), 线性结构的特点是结构中的数据元素之间存在一对一的线性关系. 这种一对一的关系指的是数据元素之间的位置关系,即: ...

  3. c/c++ 线性表之顺序表

    线性表之顺序表 存储在连续的内存空间,和数组一样. 下面的代码,最开始定义了一个能存8个元素的顺序表,当超过8个元素的时候,会再追加开辟空间(函数:reInit). 实现了以下功能: 函数 功能描述 ...

  4. [C++]线性链表之顺序表<一>

    顺序表中数据元素的存储地址是其序号的线性函数,只要确定了存储顺序表的起始地址(即 基地址),计算任意一个元素的存储地址的时间是相等的,具有这一特点的存储结构称为[随机存储]. 使用的基本数据结构:数组 ...

  5. [C++]线性链表之顺序表<二>

    /*   @content 线性链表之顺序表   @date 2017-3-21 1:06   @author Johnny Zen  */ /* 线性表     顺序表     链式表[带头指针/不 ...

  6. 线性表之顺序表C++实现

    线性表之顺序表 一.头文件:SeqList.h //顺序线性表的头文件 #include<iostream> ; //定义顺序表SeqList的模板类 template<class ...

  7. [数据结构 - 第3章] 线性表之顺序表(C++实现)

    一.类定义 顺序表类的定义如下: #ifndef SEQLIST_H #define SEQLIST_H typedef int ElemType; /* "ElemType类型根据实际情况 ...

  8. 数据结构Java实现02----线性表与顺序表

    [声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...

  9. 数据结构Java实现01----线性表与顺序表

    一.线性结构: 如果一个数据元素序列满足: (1)除第一个和最后一个数据元素外,每个数据元素只有一个前驱数据元素和一个后继数据元素: (2)第一个数据元素没有前驱数据元素: (3)最后一个数据元素没有 ...

随机推荐

  1. linux date

    我使用过的Linux命令之date - 显示.修改系统日期时间 本文链接:http://codingstandards.iteye.com/blog/1157513   (转载请注明出处) 用途说明 ...

  2. 一次使用Eclipse Memory Analyzer分析Tomcat内存溢出

    转:http://tivan.iteye.com/blog/1487855 前言 在平时开发.测试过程中.甚至是生产环境中,有时会遇到OutOfMemoryError,Java堆溢出了,这表明程序有严 ...

  3. Ajax 缓存问题

    Ajax通过GET方式请求服务器数据,Microsoft Internet Explorer浏览器下,由于缓存问题,读取的数据非最新数据,解决问题方法如下: function getData(url, ...

  4. Python关于eval与json在字典转换方面的性能比较

    背景介绍 因为python中有eval()方法,可以很方便的将一些字符串类型与字典等数据结构之间进行转换, 所以公司的数据处理同事在保存一些特殊数据时就直接将字典的字符串保存在数据库中. 在程序中读取 ...

  5. c++如何生成随机数

    一.使用rand()函数 头文件<stdlib.h> (1)  如果你只要产生随机数而不需要设定范围的话,你只要用rand()就可以了:rand()会返回一随机数值, 范围在0至RAND_ ...

  6. hibernate报错:org.hibernate.MappingException: No Dialect mapping for JDBC type: -1

    解决方法:自定义一个Hibernate Dialect. package com.yourcompany.util ; import java.sql.Types; import org.hibern ...

  7. Hibernate 查询:HQL查询(Hibernate Query Languge)

    HQL是一种面向对象的查询语言,其中没有表和字段的概念,只有类,对象和属性的概念. 使用HQL查询所有学生: public static void main(String[] args) { Sess ...

  8. pl sql练习(1)

    编写函数接受参数并返回字符串:Hello $var.然后赋值给绑定变量并打印: create or replace function hello_function ( pv_whom varchar2 ...

  9. OC准备知识

    #import 与 #include区别 include完成头文件的导入,可能会导致头文件的相互引用和函数或变量的重复定义 为了解决这个问题 我们必须这样做 #ifndef Student_h #de ...

  10. git基础命令

     git pull 更新git status 查看文件状态git add .添加所有git commit -a -m "xxxx" 提交git push 推送至服务器git dif ...