IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Java知识库 -> java入门-----一维数组及数组的增、删、查、改 -> 正文阅读

[Java知识库]java入门-----一维数组及数组的增、删、查、改

java入门-----一维数组及数组的增、删、查、改

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<names.length;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<names.length;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<names.length;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<names.length;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.length-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<is.length-1;i++){
			for(int j = 0;j<is.length-1-i;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<is.length;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;
			}
		}
	}

创作不易,如果喜欢,给个关注。。。。。

  Java知识库 最新文章
计算距离春节还有多长时间
系统开发系列 之WebService(spring框架+ma
springBoot+Cache(自定义有效时间配置)
SpringBoot整合mybatis实现增删改查、分页查
spring教程
SpringBoot+Vue实现美食交流网站的设计与实
虚拟机内存结构以及虚拟机中销毁和新建对象
SpringMVC---原理
小李同学: Java如何按多个字段分组
打印票据--java
上一篇文章      下一篇文章      查看所有文章
加:2021-07-28 23:14:42  更:2021-07-28 23:14:46 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/9 7:11:13-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码