亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

java簡(jiǎn)單實(shí)現(xiàn)數(shù)組的增刪改查方法

 更新時(shí)間:2021年07月30日 17:03:02   作者:小超0748  
這篇文章主要介紹了Java數(shù)組的增刪改查的示例,幫助大家更好的利用Java處理數(shù)據(jù),感興趣的朋友可以了解下,希望能給你帶來(lái)幫助

1.一維數(shù)組​

概念:一組數(shù)據(jù)的容器(數(shù)組可以存放多個(gè)數(shù)據(jù))

​ 注意:

​ 1.數(shù)組是引用數(shù)據(jù)類型

​ 2.數(shù)組中的數(shù)據(jù)又叫做元素

​ 3.每個(gè)元素都有編號(hào)叫做下標(biāo)/索引

​ 4.下標(biāo)從0開始

​ 5.數(shù)組初始化后,會(huì)在內(nèi)存中開辟一連串連續(xù)的空間

​ 6.數(shù)組一旦初始化后長(zhǎng)度不可以改變(數(shù)組沒有擴(kuò)容和刪除)

​ 7.數(shù)組的操作:添加、修改、查詢​

​ 數(shù)組的聲明:數(shù)據(jù)類型[] 數(shù)組名;​

數(shù)組的初始化:

​ 靜態(tài)初始化:數(shù)據(jù)由程序員指定,長(zhǎng)度由系統(tǒng)分配

public static void main(String[] args){
		//靜態(tài)初始化1
		//String[] names = new String[]{"小明","小紅","鐵蛋","二狗","大傻子"};
		//靜態(tài)初始化2
		//String[] names;
		//names = new String[]{"小明","小紅","鐵蛋","二狗","大傻子"};
		//靜態(tài)初始化3
		String[] names = {"小明","小紅","鐵蛋","二狗","大傻子"};
		//設(shè)置指定下標(biāo)上的元素
		names[3] = "大狗";
		//獲取指定下標(biāo)上的元素
		String n = names[3];
		System.out.println("獲取指定下標(biāo)上的元素:" + n);//林成
		//ArrayIndexOutOfBoundsException - 數(shù)組下標(biāo)越界異常
		//System.out.println(names[100]);
		//獲取元素個(gè)數(shù)
		int len = names.length;
		System.out.println("獲取元素個(gè)數(shù):" + len);//5
		System.out.println("-----------");
		//遍歷 - for循環(huán)
		for(int i = 0;i<names.length;i++){
			System.out.println(names[i]);
		}
		System.out.println("-----------");
		//遍歷 - foreach(增強(qiáng)for循環(huán))
		for(String str:names){//遍歷數(shù)組,依次把元素賦值給str
			System.out.println(str);
		}
		/**
			遍歷時(shí)要使用到下標(biāo),就用for循環(huán)遍歷
			遍歷時(shí)要不使用到下標(biāo),就用foreach遍歷	
		*/
	}

動(dòng)態(tài)初始化:長(zhǎng)度由程序員指定,數(shù)據(jù)由系統(tǒng)分配(默認(rèn)值)

​ 整數(shù)類型:0

​ 浮點(diǎn)類型:0.0

​ 字符類型:' '

​ 布爾類型:false

​ 引用類型:null(空)

public static void main(String[] args){
		//動(dòng)態(tài)初始化1
		String[] names = new String[5];//5->5個(gè)長(zhǎng)度
		//設(shè)置指定下標(biāo)上的元素
		names[0] = "小明";
		names[1] = "鐵蛋";
		names[2] = "二狗";
		//獲取指定下標(biāo)上的元素
		String n = names[2];
		System.out.println("獲取指定下標(biāo)上的元素:" + n);//二狗
		//ArrayIndexOutOfBoundsException - 數(shù)組下標(biāo)越界異常
		//System.out.println(names[100]);
		//獲取元素個(gè)數(shù)
		int len = names.length;
		System.out.println("獲取元素個(gè)數(shù):" + len);//5
		System.out.println("-----------");
		//遍歷 - for循環(huán)
		for(int i = 0;i<names.length;i++){
			System.out.println(names[i]);
		}
		System.out.println("-----------");
		//遍歷 - foreach(增強(qiáng)for循環(huán))
		for(String str:names){//遍歷數(shù)組,依次把元素賦值給str
			System.out.println(str);
		}
		/**
			遍歷時(shí)要使用到下標(biāo),就用for循環(huán)遍歷
			遍歷時(shí)要不使用到下標(biāo),就用foreach遍歷	
		*/

2.數(shù)組的擴(kuò)容

前面講到數(shù)組一旦初始化后長(zhǎng)度不可以改變(數(shù)組沒有擴(kuò)容和刪除),那我們?nèi)绾卧谠瓉?lái)的數(shù)組上添加數(shù)據(jù)。數(shù)組沒有擴(kuò)容,但是可以將數(shù)組中的數(shù)據(jù)從小的容器放到大的容器里。

public static void main(String[] args){
		//源數(shù)組
		String[] names = {"小明","小紅","鐵蛋","二狗"};
		//新數(shù)組
		//(names.length>>1在此次可以理解為(names.length/2)
		int capacity = names.length + (names.length>>1);//新容量:是源數(shù)組長(zhǎng)度的1.5倍
		String[] newNames = new String[capacity];
		//把源數(shù)組所有的數(shù)據(jù)遷移到新數(shù)組中
		for(int i = 0;i<names.length;i++){
			newNames[i] = names[i];
		}
		//將新數(shù)組的地址賦值給源數(shù)組
		names = newNames;
		//遍歷源數(shù)組
		for(String name:names){
			System.out.println(name);
		}
	}

小明小紅鐵蛋二狗 null null

3.數(shù)組的復(fù)制

1.直接將數(shù)組賦值給新數(shù)組

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

String[] newNames = names;

這樣做會(huì)有一個(gè)小缺陷,修改源數(shù)組,新數(shù)組的數(shù)據(jù)也隨之改變.這是因?yàn)橘x值號(hào)所給到的不是原數(shù)組的數(shù)據(jù),而是原數(shù)組的地址。

public class Test111 {
	public static void main(String[] args){
	    //源數(shù)組
	    String[] names = {"小明","小紅","鐵蛋","二狗"};
	    //新數(shù)組
	    String[] newNames = names;
	    //遍歷新數(shù)組
	    System.out.print("修改原數(shù)據(jù)前:");
	    for(String name : newNames){
	        System.out.print(name+"\t");
	    }
	    System.out.println();
	    //修改源數(shù)組
	    names[0] = "大傻子";
	    //遍歷新數(shù)組
	    System.out.print("修改原數(shù)據(jù)后:");
	    for(String name : newNames){
	        System.out.print(name+"\t");
	    }
	    System.out.println();
	}
}

修改原數(shù)據(jù)前:小明 小紅 鐵蛋 二狗 修改原數(shù)據(jù)后:大傻子 小紅 鐵蛋 二狗

2.創(chuàng)建一個(gè)新的數(shù)組,再將原數(shù)組的數(shù)據(jù)逐個(gè)賦值

public static void main(String[] args){
		//源數(shù)組
		String[] names = {"小明","小紅","鐵蛋","二狗"};
		//新數(shù)組
		String[] newNames = new String[names.length];
		//將源數(shù)組中數(shù)據(jù)依次賦值給新數(shù)組
		for(int i = 0;i<names.length;i++){
			newNames[i] = names[i];
		}
		//修改源數(shù)組
		names[0] = "大聰明";
		//遍歷新數(shù)組
		for(String name : newNames){
			System.out.println(name);
		}
	}

小明 小紅 鐵蛋 二狗

4.數(shù)組的刪除

1.新建一個(gè)小容量的數(shù)組,然后將不刪除的數(shù)據(jù)導(dǎo)入。排除了需要?jiǎng)h除的數(shù)據(jù)

缺點(diǎn):數(shù)組原本是存放數(shù)據(jù)的,刪除元素后,數(shù)組長(zhǎng)度變短

public static void main(String[] args){
		//源數(shù)組
		String[] names = {"小明","小紅","鐵蛋","二狗"};
		//新數(shù)組
		String[] newNames = new String[names.length-1];
		//將源數(shù)組的數(shù)據(jù)遷移到新數(shù)組中,要?jiǎng)h除的元素(深田詠美)除外
		int index = 0;//新數(shù)組的下標(biāo)
		for(String name:names){
			if(!name.equals("小紅")){
				newNames[index] = name;
				index++;
			}
		}
		//將新數(shù)組的地址賦值給源數(shù)組
		names = newNames;
		//遍歷源數(shù)組
		for(String name:names){
			System.out.println(name);
		}
	}

小明 鐵蛋 二狗

2.將需要?jiǎng)h除的數(shù)據(jù)后面的數(shù)據(jù)整體向前移,覆蓋掉刪除的數(shù)據(jù),這樣就可以留出空間了
public static void main(String[] args){
		//源數(shù)組
		String[] names = {"小明","小紅","鐵蛋","二狗"};
		//數(shù)據(jù)的遷移
		for(int i = 1;i<names.length-1;i++){
			names[i] = names[i+1];
		}
		names[names.length-1] = null;
		//遍歷源數(shù)組
		for(String name:names){
			System.out.println(name);
		}
	}

小明鐵蛋二狗 null

5.數(shù)組的排序

數(shù)組的排序方法有很多種,今天就分享比較簡(jiǎn)單的冒泡排序

​ 口訣:

​ N個(gè)數(shù)字來(lái)排序

​ 兩兩相比小靠前

​ 外層循環(huán)N-1

​ 內(nèi)層循環(huán)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);
		}
	}

這里分享一個(gè)Arrays工具類,導(dǎo)入Arrays包后可直接調(diào)用里面的排序方法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.數(shù)組的查找

1.順序查找:從頭到尾遍歷(簡(jiǎn)單除暴,效率相對(duì)較低)

for(int i = 0;i<is.length;i++){
			if(is[i] == num){
				System.out.println("查找到了");
			}
		}

2.二分法查找

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

​ 排序時(shí)就可以使用Arrays.sort(is);

**二分法查找適用于數(shù)據(jù)量較大時(shí),但是數(shù)據(jù)需要先排好順序。

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

總結(jié)

本篇文章就到這里了,希望能給你帶來(lái)幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!

相關(guān)文章

  • Java中常用解析工具jackson及fastjson的使用

    Java中常用解析工具jackson及fastjson的使用

    今天給大家?guī)?lái)的是關(guān)于Java解析工具的相關(guān)知識(shí),文章圍繞著jackson及fastjson的使用展開,文中有非常詳細(xì)的介紹及代碼示例,需要的朋友可以參考下
    2021-06-06
  • spring boot 默認(rèn)異常處理的實(shí)現(xiàn)

    spring boot 默認(rèn)異常處理的實(shí)現(xiàn)

    這篇文章主要介紹了spring boot 默認(rèn)異常處理的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • spark之Standalone模式部署配置詳解

    spark之Standalone模式部署配置詳解

    這篇文章主要介紹了spark之Standalone模式部署配置詳解,小編覺得挺不錯(cuò)的,這里分享給大家,供各位參考。
    2017-10-10
  • Java如何實(shí)現(xiàn)單鏈表的增刪改查

    Java如何實(shí)現(xiàn)單鏈表的增刪改查

    這篇文章主要給大家介紹了關(guān)于Java如何實(shí)現(xiàn)單鏈表的增刪改查的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • 解讀Java中char類型相加的問(wèn)題

    解讀Java中char類型相加的問(wèn)題

    這篇文章主要介紹了解讀Java中char類型相加的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • 解析Apache Dubbo的SPI實(shí)現(xiàn)機(jī)制

    解析Apache Dubbo的SPI實(shí)現(xiàn)機(jī)制

    SPI全稱為Service Provider Interface,對(duì)應(yīng)中文為服務(wù)發(fā)現(xiàn)機(jī)制。SPI類似一種可插拔機(jī)制,首先需要定義一個(gè)接口或一個(gè)約定,然后不同的場(chǎng)景可以對(duì)其進(jìn)行實(shí)現(xiàn),調(diào)用方在使用的時(shí)候無(wú)需過(guò)多關(guān)注具體的實(shí)現(xiàn)細(xì)節(jié)
    2021-06-06
  • Mybatis-Plus實(shí)現(xiàn)公共字段自動(dòng)填充的項(xiàng)目實(shí)踐

    Mybatis-Plus實(shí)現(xiàn)公共字段自動(dòng)填充的項(xiàng)目實(shí)踐

    本文主要介紹了Mybatis-Plus實(shí)現(xiàn)公共字段自動(dòng)填充的項(xiàng)目實(shí)踐,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-07-07
  • java中對(duì)象為null時(shí)的打印輸出方式

    java中對(duì)象為null時(shí)的打印輸出方式

    這篇文章主要介紹了java中對(duì)象為null時(shí)的打印輸出方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-09-09
  • SpringBoot + vue2.0查詢所用功能詳解

    SpringBoot + vue2.0查詢所用功能詳解

    這篇文章主要介紹了SpringBoot + vue2.0查詢所用功能,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2023-11-11
  • 如何在Mac下配置多個(gè)Java版本

    如何在Mac下配置多個(gè)Java版本

    這篇文章主要介紹了如何在Mac下配置多個(gè)Java版本以及需要注意的點(diǎn)詳細(xì)說(shuō)明,需要的朋友參考下步驟吧。
    2018-02-02

最新評(píng)論