• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >C语言 > C语言 数据结构之连续存储数组的算法

C语言 数据结构之连续存储数组的算法

作者: 字体:[增加 减小] 来源:互联网 时间:2017-05-28

通过本文主要向大家介绍了c语言数组排序算法,c语言数组大小,c语言定义一个数组,c语言结构体数组,c语言数组等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

数据结构之数组定义及基本操作

  数据结构中最基本的一个结构就是线性结构,而线性结构又分为连续存储结构和离散存储结构。所谓的连续存储结构其实就是数组。

  数组本质其实也是数据的一种存储方式,既然有了数据的存储,就会涉及到如何对数据进行寻址的问题。首先,先说一下在数组中数据是如何存储的,在内存中,数组中的数据是以一组连续的数据集合的形式存在于内存中。当我们访问存在于内存中的数组时,我们应该找到其在内存中的地址,当我们找到数据的地址后我们就可以找到对应的数据。了解了以上知识后,我们就可以进行数组的设计了(我们就可以设计自己的数组供别人去使用了,哈哈)。

  了解了以上知识后,第一个问题就来了,如何才能找到数据在内存中的地址?这个问题其实很简单,因为数组在内存中是一组连续的数据集合,所以我们只要知道数组首地址,然后通过对应字节长度的加减就可以找到对应字节数的数据,有了这些就可以定义出我们的数组,但是,作为一个合理的数组,还应该有数组长度的标志len和数组有效元素的标志cnt。由此给出对数组的定义(本例中采用结构体,对结构体不了解的朋友可以去查一下)

struct Arr
{
  int *pBase; //存储的是数组的第一个元素的地址
  int len; //数组所能容纳的最大元素的个数
  int cnt; //数组有效元素的个数  

};
</div>

上述代码定义了一个struct Arr的结构体,这个结构体就是一个数组,其中有存储数组元素中首地址的成员,有存储数组长度和数组有效元素个数的成员。

  有了对结构体的定义之后,就应该涉及到对数组的基本操作,包括数组的初始化,判断数组是否为空,对数组进行显示,判断数组是否已满,对数组的最后追加一个元素,对数组元素的插入。其中,主要的算法就是对数组元素的插入,插入算法的核心就是首先应该先将被插入及插入位置之后的元素后移,然后将空出来的位置插入我们要插入的元素。一下给出c语言的实现:

/*
数组初始化函数 
初始化仅仅是给出一个具有一定长度的数组,但是数组中没有有效值 
*/
void init_arr(struct Arr * pArr,int len)
{
  pArr->pBase=(int *)malloc(sizeof(int)*len);
  if(NULL==pArr->pBase){
    printf("动态内存分配失败");
    exit(-1); //终止整个程序 
  }
  else{
    pArr->len=len;
    pArr->cnt=0;
  }
}

/*
判断数组是否为空的函数 
*/ 
int is_empty(struct Arr * pArr){
  if(pArr->cnt==0){
    return 0;  //0代表true 
  }
  else{
    return 1;  //1代表false 
  }
}

/*
数组输出显示函数 
在进行数组输出时,首先应该判断数组是否为空 
*/
void show_arr(struct Arr * pArr){  
  if(is_empty(pArr)==0){
    printf("当前数组为空!");
  }
  else{
    int i;
    for(i=0; i<pArr->cnt; ++i){
      printf("%d  ",pArr->pBase[i]);
    }
    printf("\n");
  }
}

/*
判断数组是否已满的函数 
*/
int is_full(struct Arr * pArr){
  if(pArr->cnt==pArr->len){
    return 0; //0代表true,表示已满 
  }
  else{
    return 1; //1代表false,表示未满 
  }
}

/*
在数组的最后追加一个元素 
在追加数组元素前要判断当前数组是否已满,已满时不允许追加新的元素 
*/
int append_arr(struct Arr *pArr,int val){
  if(is_full(pArr)==0){
    return 0;
  }
  else{
    pArr->pBase[pArr->cnt]=val;
    pArr->cnt++;
    return 1;
  }
}

/*
在数组的指定位置插入元素 
插入算法:首先将被插入位置的元素全部后移,然后再将空出来的位置插入。
根据算法原理,所以,在插入的时候应该检查数组是否已满。 
上述两种情况均合理时,进行数据的插入,插入时,若插入第三个位置,实际是将数据赋值给arr[pos-1] 
注意:再将插入位置后的元素后移时,应该从后向前移动。否则,将会造成“被移到”的位置的值被覆盖 
*/
int insert_arr(struct Arr *pArr,int pos,int val){
  if(is_full(pArr)==0){
    return 0; //0表示当前数组已满,无法再进行插入 
  }  
  //在数组可插入的情况下,应该检查用户输入的pos位置值是否合理
  if(pos<0||pos>(pArr->len)){
    return 1; //1表示当前用户插入位置不合法 
  } 
  //移动位置 
  int i;
  for(i=pArr->cnt  -1;i>=pos-1;--i){
    pArr->pBase[i+1]=pArr->pBase[i];
  } 
  //空缺位置插入元素
  pArr->pBase[pos-1]=val;
  return 2; //2表示当前插入成功 
}
</div>

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • C语言 数据结构之连续存储数组的算法
  • C语言输出旋转后数组中的最小数元素的算法原理与实例

相关文章

  • 2017-05-28详解C++编程中的输入输相关的类和对象
  • 2017-05-28C语言中的强符号和弱符号介绍
  • 2017-05-28C语言打印杨辉三角示例汇总
  • 2017-05-28深入理解C++的多态性
  • 2017-05-28C++和java设计模式之单例模式
  • 2017-05-28C语言 用指针作为函数返回值详解
  • 2017-05-28C++事件驱动型银行排队模拟
  • 2017-05-28C 语言基础教程(我的C之旅开始了)[二]
  • 2017-05-28头文件不宜定义变量的原因全面解析
  • 2017-05-28C++求阶乘的两种方法

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • 详解C语言中printf输出的相关函数
    • 使用C++的string实现高精度加法运算的实例代码
    • C/C++实现字符串模糊匹配
    • 深入第K大数问题以及算法概要的详解
    • C++ 实现2048游戏示例
    • 如何查看进程实际的内存占用情况详解
    • C++中用指向数组的指针作函数参数
    • C语言main函数的参数及其返回值详细解析
    • C++中结构体的类型定义和初始化以及变量引用
    • 基于list循环删除元素,迭代器失效的问题详解

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有