java简单实现数组的增删改查方法
admin
2023-05-02 05:31:12
目录

        1.一维数组​

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

        ​ 注意:

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

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

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

        ​ 4.下标从0开始

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

        ​ 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
        

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

        ​ 整数类型: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
        

        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
        

        小明小红铁蛋二狗 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
        

        小明 小红 铁蛋 二狗

        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
        

        小明铁蛋二狗 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 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
        

        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;
        			}
        		}
        	}
        

        总结

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

        相关内容

        热门资讯

        demo什么意思 demo版本... 618快到了,各位的小金库大概也在准备开闸放水了吧。没有小金库的,也该向老婆撒娇卖萌服个软了,一切只...
        北京的名胜古迹 北京最著名的景... 北京从元代开始,逐渐走上帝国首都的道路,先是成为大辽朝五大首都之一的南京城,随着金灭辽,金代从海陵王...
        苗族的传统节日 贵州苗族节日有... 【岜沙苗族芦笙节】岜沙,苗语叫“分送”,距从江县城7.5公里,是世界上最崇拜树木并以树为神的枪手部落...
        世界上最漂亮的人 世界上最漂亮... 此前在某网上,选出了全球265万颜值姣好的女性。从这些数量庞大的女性群体中,人们投票选出了心目中最美...
        长白山自助游攻略 吉林长白山游... 昨天介绍了西坡的景点详细请看链接:一个人的旅行,据说能看到长白山天池全凭运气,您的运气如何?今日介绍...
        猫咪吃了塑料袋怎么办 猫咪误食... 你知道吗?塑料袋放久了会长猫哦!要说猫咪对塑料袋的喜爱程度完完全全可以媲美纸箱家里只要一有塑料袋的响...
        阿西吧是什么意思 阿西吧相当于... 即使你没有受到过任何外语培训,你也懂四国语言。汉语:你好英语:Shit韩语:阿西吧(아,씨발! )日...
        应用未安装解决办法 平板应用未... ---IT小技术,每天Get一个小技能!一、前言描述苹果IPad2居然不能安装怎么办?与此IPad不...
        脚上的穴位图 脚面经络图对应的... 人体穴位作用图解大全更清晰直观的标注了各个人体穴位的作用,包括头部穴位图、胸部穴位图、背部穴位图、胳...
        demo什么意思 demo版本... 618快到了,各位的小金库大概也在准备开闸放水了吧。没有小金库的,也该向老婆撒娇卖萌服个软了,一切只...
        北京的名胜古迹 北京最著名的景... 北京从元代开始,逐渐走上帝国首都的道路,先是成为大辽朝五大首都之一的南京城,随着金灭辽,金代从海陵王...
        苗族的传统节日 贵州苗族节日有... 【岜沙苗族芦笙节】岜沙,苗语叫“分送”,距从江县城7.5公里,是世界上最崇拜树木并以树为神的枪手部落...
        长白山自助游攻略 吉林长白山游... 昨天介绍了西坡的景点详细请看链接:一个人的旅行,据说能看到长白山天池全凭运气,您的运气如何?今日介绍...
        脚上的穴位图 脚面经络图对应的... 人体穴位作用图解大全更清晰直观的标注了各个人体穴位的作用,包括头部穴位图、胸部穴位图、背部穴位图、胳...
        应用未安装解决办法 平板应用未... ---IT小技术,每天Get一个小技能!一、前言描述苹果IPad2居然不能安装怎么办?与此IPad不...
        阿西吧是什么意思 阿西吧相当于... 即使你没有受到过任何外语培训,你也懂四国语言。汉语:你好英语:Shit韩语:阿西吧(아,씨발! )日...
        猫咪吃了塑料袋怎么办 猫咪误食... 你知道吗?塑料袋放久了会长猫哦!要说猫咪对塑料袋的喜爱程度完完全全可以媲美纸箱家里只要一有塑料袋的响...
        demo什么意思 demo版本... 618快到了,各位的小金库大概也在准备开闸放水了吧。没有小金库的,也该向老婆撒娇卖萌服个软了,一切只...