顺序表结构可设为一个数组和一个指向尾部的变量,数组用来存放元素,指向尾部的变量在插入元素的时候加一,删除元素的时候减一,始终指向尾部。

 typedef int elemtype;

 typedef struct arrayList{
elemtype date[MAXSIZE];
int last;
}ArrayList;

初始化时给对应的指针分配空间,并使last=-1

 ArrayList *init_ArrayList(){

     ArrayList *a = (ArrayList *)malloc(sizeof(ArrayList));
if(a==NULL)
return NULL; a->last = -;
return a; }

插入元素:插入位置为x,使>=x的所有元素向后移动一个位置,然后在该位置插入新元素

 int insertList(ArrayList *a,elemtype e,int x) {

     if(a->last>=MAXSIZE-){
printf("顺序表已满");
return ;
} //顺序表需要顺序插入,即不能在last外插入
if(x< || x>a->last+){
printf("插入位置错误\n");
return ;
} int i;
for(i=a->last;i>=x-;i--)//last代表数组最后一个元素的下标
a->date[i+] = a->date[i];//节点依次向后移动一个位置
a->date[i+] = e;
a->last++;
return ; }

删除元素:使位置x后的所有元素向前移动一个位置

 int deleteList(ArrayList *a,int x){

     if(x< || x>a->last)
return ; int i;
for(i=x;i<=a->last;i++)
a->date[i-] = a->date[i];
a->last--;
return ; }

遍历

 void printList(ArrayList *a){

     int i;
for(i=;i<=a->last;i++)
printf("%d ",a->date[i]); }

试运行:

void main(){

    ArrayList *init_ArrayList();
int insertList(ArrayList *a,elemtype e,int x);
int deleteList(ArrayList *a,int x);
void printList(ArrayList *a); ArrayList *arrayList = init_ArrayList();
if(arrayList==NULL){
printf("空间分配失败");
return ;
}
printf("创建成功\n"); insertList(arrayList,,);
insertList(arrayList,,);
insertList(arrayList,,);
insertList(arrayList,,);
insertList(arrayList,,); deleteList(arrayList,); printList(arrayList); }

结果:

对于顺序表查找最为方便快捷:

 int getPois(ArrayList *a,elemtype e){//获得位置 

     int i;
for(i=;i<=a->last;i++){
if(a->date[i]==e)
return i+;
}
return -; } elemtype getEle(ArrayList *a,int x){//获得元素 if(x< || x>a->last+)
return -; return a->date[x-]; }

C语言顺序表的更多相关文章

  1. C++语言------顺序表实现,用动态数组的方法

    C++ 中常用的一些东西,通过使用动态数组来实现顺序表, 掌握了一下知识点: 1.预处理有三中方法 宏定义,文件包含,条件编译 2.使用同名的变量时,可以在外层使用命名空间 类解决变量名重定义的错误 ...

  2. C语言顺序表的实现

    今天本来想写段代码练练手,想法挺好结果,栽了个大跟头,在这个错误上徘徊了4个小时才解决,现在分享出来,给大家提个醒,先贴上代码: /********************************** ...

  3. C语言——顺序表插入、删除、定位运算算法

    说明:将元素x插入到顺序表L的第i个数据元素之前,这个i是从1开始的,但是程序中数组都是从0算起的,不要混淆了. 头文件: header.h // 顺序表的结构定义 #define Maxsize 1 ...

  4. c语言-顺序表

    在数据结构中包含两种,一种线性结构(包括顺序表,链表,栈,队列),一种非线性结构(树,图), 顺序表,其实就是在内存动态数组,Java中的ArrayList就是一个典型的顺序表,它在顺序表的基础上增加 ...

  5. 数据结构C语言顺序表

    #include <stdio.h> #include <stdlib.h> typedef int EmenType; typedef struct Node { int d ...

  6. 数据结构C语言版--动态顺序表的基本功能实现(二)

    /* * 若各个方法结构体变量参数为: &L(即地址符加变量)则结构体变量访问结构成员变量时使用"." * 若为:*L(即取地址符加变量)则结构体变量访问结构体成员变量使用 ...

  7. C语言实现顺序表

    C语言实现顺序表代码 文件SeqList.cpp #pragma warning(disable: 4715) #include"SeqList.h" void ShowSeqLi ...

  8. 数据结构与算法之顺序表C语言实现

    顺序表等相关概念请自行查阅资料,这里主要是实现. 注: 1.顺序表C语言实现: 2.按较简单的方式实现,主要帮助理解,可在此基础上修改,更加完善: 3.提供几个简单函数,可自行添加功能: 4.可用C+ ...

  9. c语言进阶12-线性表之顺序表

    一.  线性表的定义 为什么要学习线性表呢? 因为我们日常生活中存在种数据关系,计算机程序是为了解决日常生活的数据关系,因此我们要学习线性表. 线性表是什么呢? 线性表是由n个元素组成的有限序列. 需 ...

随机推荐

  1. C# Request获取URL常见用法

    如果测试的url地址是http://www.test.com/testweb/default.aspx, 结果如下: Request.ApplicationPath: /testweb Request ...

  2. mysql中通过my.cnf设置默认字符集utf-8

    选项配置 配置文件路径:/full/path/mysql/bin/my.cnf (默认为/etc/my.cnf ) [client] default-character-set=utf8 [mysql ...

  3. Android-删除指定包名的App

    /** * check and delete the old package app if it exists. */ private void checkOldPackage() { String ...

  4. js数组 标签: javascript 2016-08-03 14:15 131人阅读 评论(0) 收藏

    数组排序 reverse()方法 reverse()方法会反转数组的顺序. sort()方法 默认情况下sort()方法按升序排列数组项.为实现排序sort()方法调用每项的toString(),然后 ...

  5. 20140322 卡迪夫城VS利物浦,拔出重剑,有惊无险

    一.菱形442 起初在客战南安普顿的时候,罗杰斯启用了菱形442阵式,阵容和今天客战卡迪夫城几乎一样,只是格伦·约翰逊打左后卫,弗拉纳甘任职右后卫,目的是为了在客场抵御卢克·肖+拉拉纳.当时库蒂尼奥的 ...

  6. hdu 6216 A Cubic number and A Cubic Number【数学题】

    hdu 6216 A Cubic number and A Cubic Number[数学] 题意:判断一个素数是否是两个立方数之差,就是验差分.. 题解:只有相邻两立方数之差才可能,,因为x^3-y ...

  7. hdu-3074 Multiply game---线段树+单点更新

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=3074 题目大意: 给一些数,进行点更新或者是区间计算乘积 解题思路: 裸的线段树,注意空间开大点 # ...

  8. 关于Hibernate的报错org.hibernate.MappingException: Unknown entity

    部分异常,如下 org.hibernate.MappingException: Unknown entity: com.zcd.hibernate.oneToMany.Teamat org.hiber ...

  9. UVa 658 - It's not a Bug, it's a Feature!(Dijkstra + 隐式图搜索)

    链接: https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem& ...

  10. 显示mac电脑中隐藏的文件和文件夹

    显示mac电脑中隐藏的文件和文件夹的办法:打开电脑,cd到相应的文件夹,输入以下命令,为显示隐藏的文件和文件夹 defaults write com.apple.finder AppleShowAll ...