java简单实现数组的增删改查方法

网友投稿 308 2022-10-08


java简单实现数组的增删改查方法

目录1.一维数组​2.数组的扩容3.数组的复制1.直接将数组赋值给新数组2.创建一个新的数组,再将原数组的数据逐个赋值4.数组的删除5.数组的排序6.数组的查找1.顺序查找:从头到尾遍历(简单除暴,效率相对较低)2.二分法查找总结

1.一维数组​

概念:一组数据的容器(数组可以存放多个数据)

​ 注意:

​ 1.数组是引用数据类型

​ 2.数组中的数据又叫做元素

​ 3.每个元素都有编号叫做下标/索引

​ 4.下标从0开始

​ 5.数组初始化后,会在内存中CehvZJxxNu开辟一连串连续的空间

​ 6.数组一旦初始化后长度不可以改变(数组没有扩容和删除)

​ 7.数组的操作:添加、修改、查询​

​ 数组的声明:数据类型[] 数组名;​

数组的初始化:

​ 静态初始化:数据由程序员指定,长度由系统分配

public static void main(String[] args){

//静态初始化1

//String[] names = new String[]{"小明","小红","铁蛋","二狗","大傻子"};

//静态初始化2

//String[] names;

//names = new String[]{"小明","小红","铁蛋","二狗","大傻子"};

//静态初始化3

String[] names = {"小明","小红","铁蛋","二狗","大傻子"};

//设置指定下标上的元素

names[3] = "大狗";

//获取指定下标上的元素

String n = names[3];

System.out.println("获取指定下标上的元素:" + n);//林成

//ArrayIndexOutOfBoundsException - 数组下标越界异常

//System.out.println(names[100]);

//获取元素个数

int len = names.length;

System.out.println("获取元素个数:" + len);//5

System.out.println("-----------");

//遍历 - for循环

for(int i = 0;i

System.out.println(names[i]);

}

System.out.println("-----------");

//遍历 - foreach(增强for循环)

for(String str:names){//遍历数组,依次把元素赋值给str

System.out.println(str);

}

/**

遍历时要使用到下标,就用for循环遍历

遍历时要不使用到下标,就用foreach遍历

*/

}

动态初始化:长度由程序员指定,数据由系统分配(默认值)

​ 整数类型:0

​ 浮点类型:0.0

​ 字符类型:' '

​ 布尔类型:false

​ 引用类型:null(空)

public static void main(String[] args){

//动态初始化1

String[] names = new String[5];//5->5个长度

//设置指定下标上的元素

names[0] = "小明";

names[1] = "铁蛋";

names[2] = "二狗";

//获取指定下标上的元素

String n = names[2];

System.out.println("获取指定下标上的元素:" + n);//二狗

//ArrayIndexOutOfBoundsException - 数组下标越界异常

//System.out.println(names[100]);

//获取元素个数

int len = names.length;

System.out.println("获取元素个数:" + len);//5

System.out.println("-----------");

//遍历 - for循环

for(int i = 0;i

System.out.println(names[i]);

}

System.out.println("-----------");

//遍历 - foreach(增强for循环)

for(String str:names){//遍历数组,依次把元素赋值给str

System.out.println(str);

}

/**

遍历时要使用到下标,就用for循环遍历

遍历时要不使用到下标,就用foreach遍历

*/

2.数组的扩容

前面讲到数组一旦初始化后长度不可以改变(数组没有扩容和删除),那我们如何在原来的数组上添加数据。数组没有扩容,但是可以将数组中的数据从小的容器放到大的容器里。

public static void main(String[] args){

//源数组

String[] names = {"小明","小红","铁蛋","二狗"};

//新数组

//(names.length>>1在此次可以理解为(names.length/2)

int capacity = names.length + (names.length>>1);//新容量:是源数组长度的1.5倍

String[] newNames = new String[capacity];

//把源数组所有的数据迁移到新数组中

for(int i = 0;i

newNames[i] = names[i];

}

//将新数组的地址赋值给源数组

names = newNames;

//遍历源数组

for(String name:names){

System.out.println(name);

}

}

小明小红铁蛋二狗 null null

3.数组的复制

1.直接将数组赋值给新数组

String[] names = {“小明”,“小红”,“铁蛋”,“二狗”};

String[] newNames = names;

这样做会有一个小缺陷,修改源数组,新数组的数据也随之改变.这是因为赋值号所给到的不是原数组的数据,而是原数组的地址。

public class Test111 {

public static void main(String[] args){

//源数组

String[] names = {"小明","小红","铁蛋","二狗"};

//新数组

String[] newNames = names;

//遍历新数组

System.out.print("修改原数据前:");

for(String name : newNames){

System.out.print(name+"\t");

}

System.out.println();

//修改源数组

names[0] = "大傻子";

//遍历新数组

System.out.print("修改原数据后:");

for(String name : newNames){

System.out.print(name+"\t");

}

System.out.println();

}

}

修改原数据前:小明 小红 铁蛋 二狗 修改原数据后:大傻子 小红 铁蛋 二狗

2.创建一个新的数组,再将原数组的数据逐个赋值

public static void main(String[] args){

//源数组

String[] names = {"小明","小红","铁蛋","二狗"};

//新数组

String[] newNames = new String[names.length];

//将源数组中数据依次赋值给新数组

for(int i = 0;i

newNames[i] = names[i];

}

//修改源数组

names[0] = "大聪明";

//遍历新数组

for(String name : newNames){

System.out.println(name);

}

}

小明 小红 铁蛋 二狗

4.数组的删除

1.新建一个小容量的数组,然后将不删除的数据导入。排除了需要删除的数据

缺点:数组原本是存放数据的,删除元素后,数组长度变短

public static void main(String[] args){

//源数组

String[] names = {"小明","小红","铁蛋","二狗"};

//新数组

String[] newNames = new String[names.length-1];

//将源数组的数据迁移到新数组中,要删除的元素(深田咏美)除外

int index = 0;//新数组的下标

for(String name:names){

if(!name.equals("小红")){

newNames[index] = name;

index++;

}

}

//将新数组的地址赋值给源数组

names = newNames;

//遍历源数组

for(String name:names){

System.out.println(name);

}

}

小明 铁蛋 二狗

2.将需要删除的数据后面的数据整体向前移,覆盖掉删除的数据,这样就可以留出空间了

public static void main(String[] args){

//源数组

String[] names = {"小明","小红","铁蛋","二狗"};

//数据的迁移

for(int i = 1;i

names[i] = names[i+1];

}

names[names.length-1] = null;

//遍历源数组

for(String name:names){

System.out.println(name);

}

}

小明铁蛋二狗 null

5.数组的排序

数组的排序方法有很多种,今天就分享比较简单的冒泡排序

​ 口诀:

​ N个数字来排序

​ 两两相比小靠前

​ 外层循环N-1

​ 内层循环N-1-i

public static void main(String[] args){

int[] is = {39,77,27,20,45,62};

for(int i = 0;i

for(int j = 0;j

if(is[j] > is[j+1]){

int temp = is[j];

is[j] = is[j+1];

is[j+1] = temp;

}

}

}

for(int num : is){

System.out.println(num);

}

}

这里分享一个Arrays工具类,导入Arrays包后可直接调用里面的排序方法sort

public static void main(String[] args){

import java.util.Arrays;

int[] a={1,5,8,6};

for(int num : a){

System.out.println(num);

}

}

1 5 6 8

6.数组的查找

1.顺序查找:从头到尾遍历(简单除暴,效率相对较低)

for(int i = 0;i

if(is[i] == num){

System.out.println("查找到了");

}

}

2.二分法查找

​ 前提:先排序(效率高于顺序查找)

​ 排序时就可以使用Arrays.sort(is);

**二分法查找适用于数据量较大时,但是数据需要先排好顺序。

public static void main(String[] args){

int[] is = {39,77,27,20,45,62};

int num = 77;

//排序

Arrays.sort(is);

int start = 0;

int end = is.length-1;

while(start <= end){

int mid = (start+end)/2;

if(num >is[mid]){

start = mid+1;

}else if(num < is[mid]){

end = mid-1;

}else{

System.out.println("查找到了");

break;

}

}

}

总结

本篇文章就到这里了,希望能给你带来帮助,也希望您能够多多关注我们的更多内容!

System.out.println(names[i]);

}

System.out.println("-----------");

//遍历 - foreach(增强for循环)

for(String str:names){//遍历数组,依次把元素赋值给str

System.out.println(str);

}

/**

遍历时要使用到下标,就用for循环遍历

遍历时要不使用到下标,就用foreach遍历

*/

}

动态初始化:长度由程序员指定,数据由系统分配(默认值)

​ 整数类型:0

​ 浮点类型:0.0

​ 字符类型:' '

​ 布尔类型:false

​ 引用类型:null(空)

public static void main(String[] args){

//动态初始化1

String[] names = new String[5];//5->5个长度

//设置指定下标上的元素

names[0] = "小明";

names[1] = "铁蛋";

names[2] = "二狗";

//获取指定下标上的元素

String n = names[2];

System.out.println("获取指定下标上的元素:" + n);//二狗

//ArrayIndexOutOfBoundsException - 数组下标越界异常

//System.out.println(names[100]);

//获取元素个数

int len = names.length;

System.out.println("获取元素个数:" + len);//5

System.out.println("-----------");

//遍历 - for循环

for(int i = 0;i

System.out.println(names[i]);

}

System.out.println("-----------");

//遍历 - foreach(增强for循环)

for(String str:names){//遍历数组,依次把元素赋值给str

System.out.println(str);

}

/**

遍历时要使用到下标,就用for循环遍历

遍历时要不使用到下标,就用foreach遍历

*/

2.数组的扩容

前面讲到数组一旦初始化后长度不可以改变(数组没有扩容和删除),那我们如何在原来的数组上添加数据。数组没有扩容,但是可以将数组中的数据从小的容器放到大的容器里。

public static void main(String[] args){

//源数组

String[] names = {"小明","小红","铁蛋","二狗"};

//新数组

//(names.length>>1在此次可以理解为(names.length/2)

int capacity = names.length + (names.length>>1);//新容量:是源数组长度的1.5倍

String[] newNames = new String[capacity];

//把源数组所有的数据迁移到新数组中

for(int i = 0;i

newNames[i] = names[i];

}

//将新数组的地址赋值给源数组

names = newNames;

//遍历源数组

for(String name:names){

System.out.println(name);

}

}

小明小红铁蛋二狗 null null

3.数组的复制

1.直接将数组赋值给新数组

String[] names = {“小明”,“小红”,“铁蛋”,“二狗”};

String[] newNames = names;

这样做会有一个小缺陷,修改源数组,新数组的数据也随之改变.这是因为赋值号所给到的不是原数组的数据,而是原数组的地址。

public class Test111 {

public static void main(String[] args){

//源数组

String[] names = {"小明","小红","铁蛋","二狗"};

//新数组

String[] newNames = names;

//遍历新数组

System.out.print("修改原数据前:");

for(String name : newNames){

System.out.print(name+"\t");

}

System.out.println();

//修改源数组

names[0] = "大傻子";

//遍历新数组

System.out.print("修改原数据后:");

for(String name : newNames){

System.out.print(name+"\t");

}

System.out.println();

}

}

修改原数据前:小明 小红 铁蛋 二狗 修改原数据后:大傻子 小红 铁蛋 二狗

2.创建一个新的数组,再将原数组的数据逐个赋值

public static void main(String[] args){

//源数组

String[] names = {"小明","小红","铁蛋","二狗"};

//新数组

String[] newNames = new String[names.length];

//将源数组中数据依次赋值给新数组

for(int i = 0;i

newNames[i] = names[i];

}

//修改源数组

names[0] = "大聪明";

//遍历新数组

for(String name : newNames){

System.out.println(name);

}

}

小明 小红 铁蛋 二狗

4.数组的删除

1.新建一个小容量的数组,然后将不删除的数据导入。排除了需要删除的数据

缺点:数组原本是存放数据的,删除元素后,数组长度变短

public static void main(String[] args){

//源数组

String[] names = {"小明","小红","铁蛋","二狗"};

//新数组

String[] newNames = new String[names.length-1];

//将源数组的数据迁移到新数组中,要删除的元素(深田咏美)除外

int index = 0;//新数组的下标

for(String name:names){

if(!name.equals("小红")){

newNames[index] = name;

index++;

}

}

//将新数组的地址赋值给源数组

names = newNames;

//遍历源数组

for(String name:names){

System.out.println(name);

}

}

小明 铁蛋 二狗

2.将需要删除的数据后面的数据整体向前移,覆盖掉删除的数据,这样就可以留出空间了

public static void main(String[] args){

//源数组

String[] names = {"小明","小红","铁蛋","二狗"};

//数据的迁移

for(int i = 1;i

names[i] = names[i+1];

}

names[names.length-1] = null;

//遍历源数组

for(String name:names){

System.out.println(name);

}

}

小明铁蛋二狗 null

5.数组的排序

数组的排序方法有很多种,今天就分享比较简单的冒泡排序

​ 口诀:

​ N个数字来排序

​ 两两相比小靠前

​ 外层循环N-1

​ 内层循环N-1-i

public static void main(String[] args){

int[] is = {39,77,27,20,45,62};

for(int i = 0;i

for(int j = 0;j

if(is[j] > is[j+1]){

int temp = is[j];

is[j] = is[j+1];

is[j+1] = temp;

}

}

}

for(int num : is){

System.out.println(num);

}

}

这里分享一个Arrays工具类,导入Arrays包后可直接调用里面的排序方法sort

public static void main(String[] args){

import java.util.Arrays;

int[] a={1,5,8,6};

for(int num : a){

System.out.println(num);

}

}

1 5 6 8

6.数组的查找

1.顺序查找:从头到尾遍历(简单除暴,效率相对较低)

for(int i = 0;i

if(is[i] == num){

System.out.println("查找到了");

}

}

2.二分法查找

​ 前提:先排序(效率高于顺序查找)

​ 排序时就可以使用Arrays.sort(is);

**二分法查找适用于数据量较大时,但是数据需要先排好顺序。

public static void main(String[] args){

int[] is = {39,77,27,20,45,62};

int num = 77;

//排序

Arrays.sort(is);

int start = 0;

int end = is.length-1;

while(start <= end){

int mid = (start+end)/2;

if(num >is[mid]){

start = mid+1;

}else if(num < is[mid]){

end = mid-1;

}else{

System.out.println("查找到了");

break;

}

}

}

总结

本篇文章就到这里了,希望能给你带来帮助,也希望您能够多多关注我们的更多内容!

System.out.println(names[i]);

}

System.out.println("-----------");

//遍历 - foreach(增强for循环)

for(String str:names){//遍历数组,依次把元素赋值给str

System.out.println(str);

}

/**

遍历时要使用到下标,就用for循环遍历

遍历时要不使用到下标,就用foreach遍历

*/

2.数组的扩容

前面讲到数组一旦初始化后长度不可以改变(数组没有扩容和删除),那我们如何在原来的数组上添加数据。数组没有扩容,但是可以将数组中的数据从小的容器放到大的容器里。

public static void main(String[] args){

//源数组

String[] names = {"小明","小红","铁蛋","二狗"};

//新数组

//(names.length>>1在此次可以理解为(names.length/2)

int capacity = names.length + (names.length>>1);//新容量:是源数组长度的1.5倍

String[] newNames = new String[capacity];

//把源数组所有的数据迁移到新数组中

for(int i = 0;i

newNames[i] = names[i];

}

//将新数组的地址赋值给源数组

names = newNames;

//遍历源数组

for(String name:names){

System.out.println(name);

}

}

小明小红铁蛋二狗 null null

3.数组的复制

1.直接将数组赋值给新数组

String[] names = {“小明”,“小红”,“铁蛋”,“二狗”};

String[] newNames = names;

这样做会有一个小缺陷,修改源数组,新数组的数据也随之改变.这是因为赋值号所给到的不是原数组的数据,而是原数组的地址。

public class Test111 {

public static void main(String[] args){

//源数组

String[] names = {"小明","小红","铁蛋","二狗"};

//新数组

String[] newNames = names;

//遍历新数组

System.out.print("修改原数据前:");

for(String name : newNames){

System.out.print(name+"\t");

}

System.out.println();

//修改源数组

names[0] = "大傻子";

//遍历新数组

System.out.print("修改原数据后:");

for(String name : newNames){

System.out.print(name+"\t");

}

System.out.println();

}

}

修改原数据前:小明 小红 铁蛋 二狗 修改原数据后:大傻子 小红 铁蛋 二狗

2.创建一个新的数组,再将原数组的数据逐个赋值

public static void main(String[] args){

//源数组

String[] names = {"小明","小红","铁蛋","二狗"};

//新数组

String[] newNames = new String[names.length];

//将源数组中数据依次赋值给新数组

for(int i = 0;i

newNames[i] = names[i];

}

//修改源数组

names[0] = "大聪明";

//遍历新数组

for(String name : newNames){

System.out.println(name);

}

}

小明 小红 铁蛋 二狗

4.数组的删除

1.新建一个小容量的数组,然后将不删除的数据导入。排除了需要删除的数据

缺点:数组原本是存放数据的,删除元素后,数组长度变短

public static void main(String[] args){

//源数组

String[] names = {"小明","小红","铁蛋","二狗"};

//新数组

String[] newNames = new String[names.length-1];

//将源数组的数据迁移到新数组中,要删除的元素(深田咏美)除外

int index = 0;//新数组的下标

for(String name:names){

if(!name.equals("小红")){

newNames[index] = name;

index++;

}

}

//将新数组的地址赋值给源数组

names = newNames;

//遍历源数组

for(String name:names){

System.out.println(name);

}

}

小明 铁蛋 二狗

2.将需要删除的数据后面的数据整体向前移,覆盖掉删除的数据,这样就可以留出空间了

public static void main(String[] args){

//源数组

String[] names = {"小明","小红","铁蛋","二狗"};

//数据的迁移

for(int i = 1;i

names[i] = names[i+1];

}

names[names.length-1] = null;

//遍历源数组

for(String name:names){

System.out.println(name);

}

}

小明铁蛋二狗 null

5.数组的排序

数组的排序方法有很多种,今天就分享比较简单的冒泡排序

​ 口诀:

​ N个数字来排序

​ 两两相比小靠前

​ 外层循环N-1

​ 内层循环N-1-i

public static void main(String[] args){

int[] is = {39,77,27,20,45,62};

for(int i = 0;i

for(int j = 0;j

if(is[j] > is[j+1]){

int temp = is[j];

is[j] = is[j+1];

is[j+1] = temp;

}

}

}

for(int num : is){

System.out.println(num);

}

}

这里分享一个Arrays工具类,导入Arrays包后可直接调用里面的排序方法sort

public static void main(String[] args){

import java.util.Arrays;

int[] a={1,5,8,6};

for(int num : a){

System.out.println(num);

}

}

1 5 6 8

6.数组的查找

1.顺序查找:从头到尾遍历(简单除暴,效率相对较低)

for(int i = 0;i

if(is[i] == num){

System.out.println("查找到了");

}

}

2.二分法查找

​ 前提:先排序(效率高于顺序查找)

​ 排序时就可以使用Arrays.sort(is);

**二分法查找适用于数据量较大时,但是数据需要先排好顺序。

public static void main(String[] args){

int[] is = {39,77,27,20,45,62};

int num = 77;

//排序

Arrays.sort(is);

int start = 0;

int end = is.length-1;

while(start <= end){

int mid = (start+end)/2;

if(num >is[mid]){

start = mid+1;

}else if(num < is[mid]){

end = mid-1;

}else{

System.out.println("查找到了");

break;

}

}

}

总结

本篇文章就到这里了,希望能给你带来帮助,也希望您能够多多关注我们的更多内容!

newNames[i] = names[i];

}

//将新数组的地址赋值给源数组

names = newNames;

//遍历源数组

for(String name:names){

System.out.println(name);

}

}

小明小红铁蛋二狗 null null

3.数组的复制

1.直接将数组赋值给新数组

String[] names = {“小明”,“小红”,“铁蛋”,“二狗”};

String[] newNames = names;

这样做会有一个小缺陷,修改源数组,新数组的数据也随之改变.这是因为赋值号所给到的不是原数组的数据,而是原数组的地址。

public class Test111 {

public static void main(String[] args){

//源数组

String[] names = {"小明","小红","铁蛋","二狗"};

//新数组

String[] newNames = names;

//遍历新数组

System.out.print("修改原数据前:");

for(String name : newNames){

System.out.print(name+"\t");

}

System.out.println();

//修改源数组

names[0] = "大傻子";

//遍历新数组

System.out.print("修改原数据后:");

for(String name : newNames){

System.out.print(name+"\t");

}

System.out.println();

}

}

修改原数据前:小明 小红 铁蛋 二狗 修改原数据后:大傻子 小红 铁蛋 二狗

2.创建一个新的数组,再将原数组的数据逐个赋值

public static void main(String[] args){

//源数组

String[] names = {"小明","小红","铁蛋","二狗"};

//新数组

String[] newNames = new String[names.length];

//将源数组中数据依次赋值给新数组

for(int i = 0;i

newNames[i] = names[i];

}

//修改源数组

names[0] = "大聪明";

//遍历新数组

for(String name : newNames){

System.out.println(name);

}

}

小明 小红 铁蛋 二狗

4.数组的删除

1.新建一个小容量的数组,然后将不删除的数据导入。排除了需要删除的数据

缺点:数组原本是存放数据的,删除元素后,数组长度变短

public static void main(String[] args){

//源数组

String[] names = {"小明","小红","铁蛋","二狗"};

//新数组

String[] newNames = new String[names.length-1];

//将源数组的数据迁移到新数组中,要删除的元素(深田咏美)除外

int index = 0;//新数组的下标

for(String name:names){

if(!name.equals("小红")){

newNames[index] = name;

index++;

}

}

//将新数组的地址赋值给源数组

names = newNames;

//遍历源数组

for(String name:names){

System.out.println(name);

}

}

小明 铁蛋 二狗

2.将需要删除的数据后面的数据整体向前移,覆盖掉删除的数据,这样就可以留出空间了

public static void main(String[] args){

//源数组

String[] names = {"小明","小红","铁蛋","二狗"};

//数据的迁移

for(int i = 1;i

names[i] = names[i+1];

}

names[names.length-1] = null;

//遍历源数组

for(String name:names){

System.out.println(name);

}

}

小明铁蛋二狗 null

5.数组的排序

数组的排序方法有很多种,今天就分享比较简单的冒泡排序

​ 口诀:

​ N个数字来排序

​ 两两相比小靠前

​ 外层循环N-1

​ 内层循环N-1-i

public static void main(String[] args){

int[] is = {39,77,27,20,45,62};

for(int i = 0;i

for(int j = 0;j

if(is[j] > is[j+1]){

int temp = is[j];

is[j] = is[j+1];

is[j+1] = temp;

}

}

}

for(int num : is){

System.out.println(num);

}

}

这里分享一个Arrays工具类,导入Arrays包后可直接调用里面的排序方法sort

public static void main(String[] args){

import java.util.Arrays;

int[] a={1,5,8,6};

for(int num : a){

System.out.println(num);

}

}

1 5 6 8

6.数组的查找

1.顺序查找:从头到尾遍历(简单除暴,效率相对较低)

for(int i = 0;i

if(is[i] == num){

System.out.println("查找到了");

}

}

2.二分法查找

​ 前提:先排序(效率高于顺序查找)

​ 排序时就可以使用Arrays.sort(is);

**二分法查找适用于数据量较大时,但是数据需要先排好顺序。

public static void main(String[] args){

int[] is = {39,77,27,20,45,62};

int num = 77;

//排序

Arrays.sort(is);

int start = 0;

int end = is.length-1;

while(start <= end){

int mid = (start+end)/2;

if(num >is[mid]){

start = mid+1;

}else if(num < is[mid]){

end = mid-1;

}else{

System.out.println("查找到了");

break;

}

}

}

总结

本篇文章就到这里了,希望能给你带来帮助,也希望您能够多多关注我们的更多内容!

newNames[i] = names[i];

}

//修改源数组

names[0] = "大聪明";

//遍历新数组

for(String name : newNames){

System.out.println(name);

}

}

小明 小红 铁蛋 二狗

4.数组的删除

1.新建一个小容量的数组,然后将不删除的数据导入。排除了需要删除的数据

缺点:数组原本是存放数据的,删除元素后,数组长度变短

public static void main(String[] args){

//源数组

String[] names = {"小明","小红","铁蛋","二狗"};

//新数组

String[] newNames = new String[names.length-1];

//将源数组的数据迁移到新数组中,要删除的元素(深田咏美)除外

int index = 0;//新数组的下标

for(String name:names){

if(!name.equals("小红")){

newNames[index] = name;

index++;

}

}

//将新数组的地址赋值给源数组

names = newNames;

//遍历源数组

for(String name:names){

System.out.println(name);

}

}

小明 铁蛋 二狗

2.将需要删除的数据后面的数据整体向前移,覆盖掉删除的数据,这样就可以留出空间了

public static void main(String[] args){

//源数组

String[] names = {"小明","小红","铁蛋","二狗"};

//数据的迁移

for(int i = 1;i

names[i] = names[i+1];

}

names[names.length-1] = null;

//遍历源数组

for(String name:names){

System.out.println(name);

}

}

小明铁蛋二狗 null

5.数组的排序

数组的排序方法有很多种,今天就分享比较简单的冒泡排序

​ 口诀:

​ N个数字来排序

​ 两两相比小靠前

​ 外层循环N-1

​ 内层循环N-1-i

public static void main(String[] args){

int[] is = {39,77,27,20,45,62};

for(int i = 0;i

for(int j = 0;j

if(is[j] > is[j+1]){

int temp = is[j];

is[j] = is[j+1];

is[j+1] = temp;

}

}

}

for(int num : is){

System.out.println(num);

}

}

这里分享一个Arrays工具类,导入Arrays包后可直接调用里面的排序方法sort

public static void main(String[] args){

import java.util.Arrays;

int[] a={1,5,8,6};

for(int num : a){

System.out.println(num);

}

}

1 5 6 8

6.数组的查找

1.顺序查找:从头到尾遍历(简单除暴,效率相对较低)

for(int i = 0;i

if(is[i] == num){

System.out.println("查找到了");

}

}

2.二分法查找

​ 前提:先排序(效率高于顺序查找)

​ 排序时就可以使用Arrays.sort(is);

**二分法查找适用于数据量较大时,但是数据需要先排好顺序。

public static void main(String[] args){

int[] is = {39,77,27,20,45,62};

int num = 77;

//排序

Arrays.sort(is);

int start = 0;

int end = is.length-1;

while(start <= end){

int mid = (start+end)/2;

if(num >is[mid]){

start = mid+1;

}else if(num < is[mid]){

end = mid-1;

}else{

System.out.println("查找到了");

break;

}

}

}

总结

本篇文章就到这里了,希望能给你带来帮助,也希望您能够多多关注我们的更多内容!

names[i] = names[i+1];

}

names[names.length-1] = null;

//遍历源数组

for(String name:names){

System.out.println(name);

}

}

小明铁蛋二狗 null

5.数组的排序

数组的排序方法有很多种,今天就分享比较简单的冒泡排序

​ 口诀:

​ N个数字来排序

​ 两两相比小靠前

​ 外层循环N-1

​ 内层循环N-1-i

public static void main(String[] args){

int[] is = {39,77,27,20,45,62};

for(int i = 0;i

for(int j = 0;j

if(is[j] > is[j+1]){

int temp = is[j];

is[j] = is[j+1];

is[j+1] = temp;

}

}

}

for(int num : is){

System.out.println(num);

}

}

这里分享一个Arrays工具类,导入Arrays包后可直接调用里面的排序方法sort

public static void main(String[] args){

import java.util.Arrays;

int[] a={1,5,8,6};

for(int num : a){

System.out.println(num);

}

}

1 5 6 8

6.数组的查找

1.顺序查找:从头到尾遍历(简单除暴,效率相对较低)

for(int i = 0;i

if(is[i] == num){

System.out.println("查找到了");

}

}

2.二分法查找

​ 前提:先排序(效率高于顺序查找)

​ 排序时就可以使用Arrays.sort(is);

**二分法查找适用于数据量较大时,但是数据需要先排好顺序。

public static void main(String[] args){

int[] is = {39,77,27,20,45,62};

int num = 77;

//排序

Arrays.sort(is);

int start = 0;

int end = is.length-1;

while(start <= end){

int mid = (start+end)/2;

if(num >is[mid]){

start = mid+1;

}else if(num < is[mid]){

end = mid-1;

}else{

System.out.println("查找到了");

break;

}

}

}

总结

本篇文章就到这里了,希望能给你带来帮助,也希望您能够多多关注我们的更多内容!

for(int j = 0;j

if(is[j] > is[j+1]){

int temp = is[j];

is[j] = is[j+1];

is[j+1] = temp;

}

}

}

for(int num : is){

System.out.println(num);

}

}

这里分享一个Arrays工具类,导入Arrays包后可直接调用里面的排序方法sort

public static void main(String[] args){

import java.util.Arrays;

int[] a={1,5,8,6};

for(int num : a){

System.out.println(num);

}

}

1 5 6 8

6.数组的查找

1.顺序查找:从头到尾遍历(简单除暴,效率相对较低)

for(int i = 0;i

if(is[i] == num){

System.out.println("查找到了");

}

}

2.二分法查找

​ 前提:先排序(效率高于顺序查找)

​ 排序时就可以使用Arrays.sort(is);

**二分法查找适用于数据量较大时,但是数据需要先排好顺序。

public static void main(String[] args){

int[] is = {39,77,27,20,45,62};

int num = 77;

//排序

Arrays.sort(is);

int start = 0;

int end = is.length-1;

while(start <= end){

int mid = (start+end)/2;

if(num >is[mid]){

start = mid+1;

}else if(num < is[mid]){

end = mid-1;

}else{

System.out.println("查找到了");

break;

}

}

}

总结

本篇文章就到这里了,希望能给你带来帮助,也希望您能够多多关注我们的更多内容!

if(is[j] > is[j+1]){

int temp = is[j];

is[j] = is[j+1];

is[j+1] = temp;

}

}

}

for(int num : is){

System.out.println(num);

}

}

这里分享一个Arrays工具类,导入Arrays包后可直接调用里面的排序方法sort

public static void main(String[] args){

import java.util.Arrays;

int[] a={1,5,8,6};

for(int num : a){

System.out.println(num);

}

}

1 5 6 8

6.数组的查找

1.顺序查找:从头到尾遍历(简单除暴,效率相对较低)

for(int i = 0;i

if(is[i] == num){

System.out.println("查找到了");

}

}

2.二分法查找

​ 前提:先排序(效率高于顺序查找)

​ 排序时就可以使用Arrays.sort(is);

**二分法查找适用于数据量较大时,但是数据需要先排好顺序。

public static void main(String[] args){

int[] is = {39,77,27,20,45,62};

int num = 77;

//排序

Arrays.sort(is);

int start = 0;

int end = is.length-1;

while(start <= end){

int mid = (start+end)/2;

if(num >is[mid]){

start = mid+1;

}else if(num < is[mid]){

end = mid-1;

}else{

System.out.println("查找到了");

break;

}

}

}

总结

本篇文章就到这里了,希望能给你带来帮助,也希望您能够多多关注我们的更多内容!

if(is[i] == num){

System.out.println("查找到了");

}

}

2.二分法查找

​ 前提:先排序(效率高于顺序查找)

​ 排序时就可以使用Arrays.sort(is);

**二分法查找适用于数据量较大时,但是数据需要先排好顺序。

public static void main(String[] args){

int[] is = {39,77,27,20,45,62};

int num = 77;

//排序

Arrays.sort(is);

int start = 0;

int end = is.length-1;

while(start <= end){

int mid = (start+end)/2;

if(num >is[mid]){

start = mid+1;

}else if(num < is[mid]){

end = mid-1;

}else{

System.out.println("查找到了");

break;

}

}

}

总结

本篇文章就到这里了,希望能给你带来帮助,也希望您能够多多关注我们的更多内容!


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Nmap网络安全审计(NMPA审计)
下一篇:利用xxe获取linux系统的passwd
相关文章

 发表评论

暂时没有评论,来抢沙发吧~