Java数组操作类
最近又重新在看慕课网的数据结构,然后把示例代码整理一下。
public class Array<E> {
private E[] data;
private int count = 0;
public Array(int length){
data = (E[]) new Object[length];
}
public Array(){
this(10);
}
/**
* 获取数组长度
* @return
*/
public int getLength(){
return data.length;
}
public int getCount(){
return count;
}
public boolean isEmpty(){
return count == 0;
}
/**
* 追加元素
* @param item
*/
public Array<E> add(E item){
return add(count, item);
}
/**
* 插入元素
* @param index 索引位置
* @param item 元素
*/
public Array<E> add(int index, E item){
//元素索引必须合法,则插入位置不能造成元素位置不连续
if(index < 0 || index > count) throw new IllegalArgumentException("Get failed Index is illegal.");
if(count == data.length){
resize((int) (data.length * 1.5));
}
//插入时,从尾部开始,每个元素后移动一位,直到当前索引位置为止
for(int i = count - 1; i >= index; i--){
data[i + 1] = data[i];
}
data[index] = item;
count++;
return this;
}
/**
* 获取元素
* @param index 索引,负数表示倒数
* @return
*/
public E get(int index){
if(index < 0) index += count;
if(index >= count) throw new IllegalArgumentException("Get failed Index is illegal.");
return data[index];
}
/**
* 修改元素
* @param index 索引,负数表示倒数
* @param item
*/
public Array<E> set(int index, E item){
if(index < 0) index += count;
if(index >= count) throw new IndexOutOfBoundsException();
data[index] = item;
return this;
}
/**
* 删除给定索引位置的元素
* @param index
* @return 元素
*/
public E remove(int index){
if(index < 0) index += count;
if(index >= count) throw new IndexOutOfBoundsException();
for(int i = index; i < count - 1; i++){
data[i] = data[i + 1];
}
count--;
data[count] = null;
//收缩容量
if(count == data.length / 4 && data.length / 2 > 0){
resize(data.length / 2);
}
return data[index];
}
/**
* 删除给定元素
* @param item
* @return
*/
public boolean remove(E item){
int index = find(item);
if(index >= 0){
remove(index);
return true;
}
return false;
}
/**
* 删除所有给定元素
* @param item
* @return boolean
*/
public boolean removeAll(E item){
int index = find(item);
if(index > -1){
do{
remove(index);
index = find(item);
}while(index <= 0);
return true;
}
return false;
}
/**
* 重新分配数组长度
* @param length
*/
private void resize(int length){
E[] data = (E[]) new Object[length];
for(int i = 0; i < count; i++){
data[i] = this.data[i];
}
this.data = data;
}
/**
* 判断元素是否存在
* @param item
* @return boolean
*/
public boolean contains(E item){
return (find(item) > -1)? true : false;
}
/**
* 查找元素所在位置
* @param item
* @return 索引位置
*/
public int find(E item){
for(int i = 0; i < count; i++){
//对象之间用 equals 方法,表示值比较
if(data[i].equals(item)) return i;
}
return -1;
}
@Override
public String toString(){
StringBuilder sb = new StringBuilder();
sb.append(String.format("Array[%d]: ", data.length, count));
sb.append('[');
for(int i = 0; i < count; i++){
sb.append(data[i]);
if(i != count - 1) sb.append(", ");
}
sb.append("]");
return sb.toString();
}
}
Java数组操作类的更多相关文章
- 菜鸡的Java笔记 实践 - java 数组操作
讲解一个继承的实现思路 要求定义一个数组操作类(Array类),在这个类里面可以进行整型数组的操作,由外部传入数组的大小 ,并且要求实现数据的保存以及数据的 ...
- JAVA文件操作类和文件夹的操作代码示例
JAVA文件操作类和文件夹的操作代码实例,包括读取文本文件内容, 新建目录,多级目录创建,新建文件,有编码方式的文件创建, 删除文件,删除文件夹,删除指定文件夹下所有文件, 复制单个文件,复制整个文件 ...
- Java数组操作的10大方法
转载自码农网 译文链接:http://www.codeceo.com/article/10-java-array-method.html 英文原文:Top 10 Methods for Java Ar ...
- Java文件操作类效率对比
前言 众所周知,Java中有多种针对文件的操作类,以面向字节流和字符流可分为两大类,这里以写入为例: 面向字节流的:FileOutputStream 和 BufferedOutputStream 面向 ...
- 并发库应用之二 & Java原子性操作类应用
Java5的线程并发库中,提供了一组atomic class来帮助我们简化同步处理.基本工作原理是使用了同步synchronized的方法实现了对一个long, integer, 对象的增.减.赋值( ...
- Java 数学操作类
数学操作类 Math类 数学计算操作类 类属性值 Math.E ^ Math.PI 圆周率 类方法 Math类中,一切方法都是 static 型,因为Math类中没有普通属性. round() 方法 ...
- Java大数操作类
Java的大数操作分为BigInteger和BigDecimal,但这两给类是分开使用的,有时候在编程的时候显得略微繁琐,现在编写了一个将二者合二为一的大数操作类. 大数操作类代码如下: packag ...
- php 数组操作类(整合 给意见)
数组操作函数整理: /* 将一个二维数组按照指定字段的值分组 * * @param array $arr * @param string $keyField * * @return array */ ...
- Java数组操作十大方法 (转)
定义一个Java数组 String[] aArray = new String[5]; String[] bArray = {"a","b","c&q ...
随机推荐
- base64文件隐写脚本
base64文件隐写脚本 base64 可以在文件中隐藏信息,记录一下提取脚本 ''' base64文件隐写脚本 import re import base64 b64chars = 'ABCDEFG ...
- system.stat[resource,<type>]
系统信息. 整型或者浮点型 ent - 该分区有权接收的处理器单元数(float) kthr, - 关于内核线程状态的信息: r - 平均可运行内核线程数(float) b - 虚拟内存管理器等待队列 ...
- Javascript的数据类型(原始类型和引用类型)
1.ECMAScript3中定义了变量可分为原始值和引用值. 原始值:是保存在栈(stack)中的简单数据段:也就是说他们的值是直接存储在变量访问的位置. 引用值:是保存在堆(heap)中的对象,也就 ...
- 【cf比赛记录】Codeforces Round #600 (Div. 2)
Codeforces Round #600 (Div. 2) ---- 比赛传送门 昨晚成绩还好,AC A,B题,还能上分(到底有多菜) 补了C.D题,因为昨晚对C.D题已经有想法了,所以补起题来也快 ...
- 避免MySQL出现重复数据处理方法
对于常规的MySQL数据表中可能存在重复的数据,有些情况是允许重复数据的存在,有些情况是不允许的,这个时候我们就需要查找并删除这些重复数据,以下是具体的处理方法! 方法一:防止表中出现重复数据 当表中 ...
- minimap2 长reads比对工具
minimap2 github 官网 https://github.com/lh3/minimap2 安装 git clone https://github.com/lh3/minimap2 cd m ...
- Http、Socket、WebSocket之间联系与区别
WebSocket和Socket区别 可以把WebSocket想象成HTTP(应用层),HTTP和Socket什么关系,WebSocket和Socket就是什么关系. HTTP 协议有一个缺陷:通信只 ...
- Gamma阶段第五次scrum meeting
每日任务内容 队员 昨日完成任务 明日要完成的任务 张圆宁 #91 用户体验与优化https://github.com/rRetr0Git/rateMyCourse/issues/91(持续完成) # ...
- 工具系列 | PHPSTROM 连接Docker容器 && 配置XDEBUG调试
Docker 客户端配置 PHPSTROM 配置 选择连接 容器日志 配置Xdebug 开启Debug模式 打断点 浏览器访问该项目地址:http://wiot.frp.tinywan.top/
- android为什么不允许新开启一个线程来更新UI,而是用handler来更新界面
下面是快速创建一个新线程的方法: 第一种:直接创建子线程并启动 new Thread() {@Overridepublic void run() { //这里写入子线程需要做的工作 ...