前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >数据结构与算法(二)数组

数据结构与算法(二)数组

作者头像
老沙
发布2019-09-28 13:17:42
2990
发布2019-09-28 13:17:42
举报
文章被收录于专栏:老沙课堂老沙课堂

数组:

在堆中连续开辟的一段空间,每个元素占有相同大小的空间。一经开辟,即固定大小,无法改变长短。

对数组如何增删查改

插入
代码语言:javascript
复制
public void insetAtIndex(int index, int element) {
  cheakRange(index); // 检查插入的是否超过数组开辟范围
  cheakCapicity(); // 看是否需要扩容

  for (int i = size; i > index; i--) {
    elementDatas[i] = elementDatas[i - 1];
  }
  elementDatas[index] = element;
}
数组的插入操作 效率很低 如果数组长度特别大,在首部附近插入数据,将会把几乎所有的数组数组都要向后移动。
删除
代码语言:javascript
复制
public int removeAtIndex(int index) {
  // 检查删除的是否超过数组开辟范围
  cheakRange(index);

  int old = elementDatas[index];
  for (int i = index + 1; i < size; i++) {
    elementDatas[i - 1] = elementDatas[i];
  }
  //清空最后的空间
	elementDatas[index] = null;
}

查询

通过角标偏移就可以找到对应的数组。由于内存地址是连续的 所查数据只要是(查找数据index*偏移量)。
代码语言:javascript
复制
public int get(int index) {
	// 判断查找的是否在范围内
		cheakRange(index);
		return elementDatas[i];
}
替换
在查找的基础上直接替换就可以
代码语言:javascript
复制
elementDatas[i] = element;
  • 优点:查找,替换快
  • 缺点:插入删除效率低

注意:在数组增删查改的时候,要判断是否在数组范围内操作。

在增加的时候,如果超过数组开辟空间范围,要对数组进行扩容:重新创建一个更大的数组,再将旧数组内容拷贝过去,再进行操作。

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2019-09-20,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 老沙说点事 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 对数组如何增删查改
    • 插入
      • 数组的插入操作 效率很低 如果数组长度特别大,在首部附近插入数据,将会把几乎所有的数组数组都要向后移动。
    • 删除
      • 通过角标偏移就可以找到对应的数组。由于内存地址是连续的 所查数据只要是(查找数据index*偏移量)。
  • 查询
    • 替换
      • 在查找的基础上直接替换就可以
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档