【Java】数据结构-自定义数组的数据结构

admin 2022年1月10日03:30:48评论5 views字数 5839阅读19分27秒阅读模式

我的个人博客

孤桜懶契:http://gylq.github.io

自定义数组执行结果截图

image-20210625092414528

自定义泛型数组代码(详解)

Array.java(自定义泛型数组)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
public class Array<E> {

private E[] data;
private int size; //大小

// 构造函数 转入数组的容量capacity构造Array
public Array(int capacity){
data =(E[])new Object[capacity];
size = 0 ;
}

// 无参的构造函数,默认数组的容量capacity = 10
public Array(){
this(10); //调用有参构造函数传入10设定初始大小
}

// 获取数组中元素个数
public int getSize(){
return size;
}

// 获取数组的容量
public int getCapacity(){
return data.length;
}

//返回数组是否为空
public boolean isEmpty(){
return size == 0;
}

// 向所有元素后添加一个新元素
public void addLast(E e){

// if(size == data.length) {
// throw new IllegalArgumentException("AddLast failed. Array is full.");
// }
// data[size] = e;
// size ++;
add(size, e);
}

// 在所有元素前添加一个新元素
public void addFirst(E e){
add(0, e);
}

// 在第index个位置插入一个新元素e
public void add(int index, E e){

if(size == data.length) {
throw new IllegalArgumentException("Add failed. Array is full.");
}

if(index < 0 || index > size ){
throw new IllegalArgumentException("Add failed. Require index >=0 and index <= size.");
}

for(int i = size - 1 ; i >= index ; i --){
data[i + 1]=data[i];
}
data[index] = e;
size ++;
}

// 获取index索引位置的元素
public E get(int index){
if(index < 0 || index >= size)
throw new IllegalArgumentException("Get failed. Index is illegal.");
return data[index];
}

// 修改index索引位置的元素为e
public void set(int index, E e){
if(index < 0 || index >= size)
throw new IllegalArgumentException("set failed. Index is illegal.");
data[index] = e;

}

// 查找数组中是否有元素e
public boolean contains(E e){
for(int i = 0 ; i < size ; i++)
{
if(data[i].equals(e))
return true;
}
return false;
}

// 查找数组中元素e所在的索引,如果不存在元素e,则返回-1
public int find(E e){
for(int i = 0 ; i < size ; i++)
{
if(data[i].equals(e))
return i;
}
return -1;
}

// 从数组中删除index位置的元素,返回删除的元素
public E remove(int index){
if(index < 0 || index >= size)
{
throw new IllegalArgumentException("Remove failed. Index is illegal.");
}
E ret = data[index];
for(int i = index + 1 ; i < size ; i ++)
{
data[i-1] = data[i];
}
size --;
data[size] = null; //让他自动回收 非必须写 loitering objects != memory leak
return ret;
}

// 从数组中删除第一个元素,返回删除的元素
public E removeFirst(){
return remove(0);
}

// 从数组中删除最后一个元素,返回删除的元素
public E removeLast(){
return remove(size-1);
}

// 从数组中删除元素e
public void removeElement(E e){
int index = find(e);
if(index != -1)
remove(index);
}


//system.out.print()所输出的类型toString覆盖
@Override
public String toString(){

StringBuilder res = new StringBuilder();
res.append(String.format("Array: size = %d, capacity = %d \n", size, data.length));
res.append('[');
for(int i = 0 ; i < size ; i ++){
res.append(data[i]);
if(i != size - 1)
res.append(", ");
}
res.append(']');
return res.toString();
}
}

Array.java(自定义动态数组)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
public class Array<E> {

private E[] data;
private int size; //大小

// 构造函数 转入数组的容量capacity构造Array
public Array(int capacity){
data =(E[])new Object[capacity];
size = 0 ;
}

// 无参的构造函数,默认数组的容量capacity = 10
public Array(){
this(10); //调用有参构造函数传入10设定初始大小
}

// 获取数组中元素个数
public int getSize(){
return size;
}

// 获取数组的容量
public int getCapacity(){
return data.length;
}

//返回数组是否为空
public boolean isEmpty(){
return size == 0;
}

// 向所有元素后添加一个新元素
public void addLast(E e){

// if(size == data.length) {
// throw new IllegalArgumentException("AddLast failed. Array is full.");
// }
// data[size] = e;
// size ++;
add(size, e);
}

// 在所有元素前添加一个新元素
public void addFirst(E e){
add(0, e);
}

// 在第index个位置插入一个新元素e
public void add(int index, E e){

if(index < 0 || index > size ){
throw new IllegalArgumentException("Add failed. Require index >=0 and index <= size.");
}

if(size == data.length) {
resize(2 * data.length);
}

for(int i = size - 1 ; i >= index ; i --){
data[i + 1]=data[i];
}
data[index] = e;
size ++;
}

// 获取index索引位置的元素
public E get(int index){
if(index < 0 || index >= size)
throw new IllegalArgumentException("Get failed. Index is illegal.");
return data[index];
}

// 修改index索引位置的元素为e
public void set(int index, E e){
if(index < 0 || index >= size)
throw new IllegalArgumentException("set failed. Index is illegal.");
data[index] = e;

}

// 查找数组中是否有元素e
public boolean contains(E e){
for(int i = 0 ; i < size ; i++)
{
if(data[i].equals(e))
return true;
}
return false;
}

// 查找数组中元素e所在的索引,如果不存在元素e,则返回-1
public int find(E e){
for(int i = 0 ; i < size ; i++)
{
if(data[i].equals(e))
return i;
}
return -1;
}

// 从数组中删除index位置的元素,返回删除的元素
public E remove(int index){
if(index < 0 || index >= size)
{
throw new IllegalArgumentException("Remove failed. Index is illegal.");
}
E ret = data[index];
for(int i = index + 1 ; i < size ; i ++)
{
data[i-1] = data[i];
}
size --;
data[size] = null; //让他自动回收 非必须写 loitering objects != memory leak

if(size == data.length / 2)
resize(data.length / 2);
return ret;
}

// 从数组中删除第一个元素,返回删除的元素
public E removeFirst(){
return remove(0);
}

// 从数组中删除最后一个元素,返回删除的元素
public E removeLast(){
return remove(size-1);
}

// 从数组中删除元素e
public void removeElement(E e){
int index = find(e);
if(index != -1)
remove(index);
}


//system.out.print()所输出的类型toString覆盖
@Override
public String toString(){

StringBuilder res = new StringBuilder();
res.append(String.format("Array: size = %d, capacity = %d \n", size, data.length));
res.append('[');
for(int i = 0 ; i < size ; i ++){
res.append(data[i]);
if(i != size - 1)
res.append(", ");
}
res.append(']');
return res.toString();
}

private void resize(int newCapacity){
E[] newData = (E[])new Object[newCapacity];
for(int i = 0 ; i < size ; i ++)
newData[i] = data[i];
data = newData;
}
}

Main.java(调用自定义数组使用方法)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
public class Main {

public static void main(String[] args){

Array<Integer> arr = new Array(20);
for(int i = 0 ; i < 10 ; i ++)
arr.addLast(i);
System.out.println(arr);

//在index位置插入元素为100
arr.add(1, 100);
System.out.println(arr);

//在第一个元素前面添加一个-1的元素
arr.addFirst(-1);
System.out.println(arr);
//[-1, 0, 100, 1, 2, 3, 4, 5, 6, 7, 8, 9]

//删除索引为2的元素
arr.remove(2);
System.out.println(arr);

//删除4这个元素
arr.removeElement(4);
System.out.println(arr);

//删除第一个元素
arr.removeFirst();
System.out.println(arr);

}
}

FROM:gylq.gitee Author:孤桜懶契

  • 左青龙
  • 微信扫一扫
  • weinxin
  • 右白虎
  • 微信扫一扫
  • weinxin
admin
  • 本文由 发表于 2022年1月10日03:30:48
  • 转载请保留本文链接(CN-SEC中文网:感谢原作者辛苦付出):
                   【Java】数据结构-自定义数组的数据结构http://cn-sec.com/archives/729937.html

发表评论

匿名网友 填写信息