這篇文章將為大家詳細(xì)講解有關(guān)Java數(shù)組常見應(yīng)用的示例分析,小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。
成都創(chuàng)新互聯(lián)自2013年起,先為魏縣等服務(wù)建站,魏縣等地企業(yè),進(jìn)行企業(yè)商務(wù)咨詢服務(wù)。為魏縣企業(yè)網(wǎng)站制作PC+手機(jī)+微官網(wǎng)三網(wǎng)同步一站式服務(wù)解決您的所有建站問題。
外循環(huán)控制行,內(nèi)循環(huán)控制列。
//乘法表 for(int i = 1; i <= 9; i++) { for(int j = 1; j <= i ;j++) { System.out.print(j+"*"+i+"="+(i*j)+"\t"); } System.out.println(); }
#:一個(gè)數(shù)字
0:一個(gè)數(shù)字,不夠位數(shù)用0補(bǔ)位
DecimalFormat f = new DecimalFormat("###.##"); DecimalFormat f = new DecimalFormat("000.00000"); System.out.println(sum); System.out.println(f.format(sum)); System.out.println(f.format(34.567));
用在 switch和循環(huán)中。
用在單層循環(huán)中,用來結(jié)束循環(huán)。
用在循環(huán)中。
作用 結(jié)束本次循環(huán)進(jìn)行下一次循環(huán)條件判斷。
對(duì)于雙重循環(huán),可以自定義一個(gè)標(biāo)簽,break或continue 到標(biāo)簽處。
Java 語言中提供的數(shù)組是用來存儲(chǔ)固定大小的同類型元素。
首先必須聲明數(shù)組變量,才能在程序中使用數(shù)組。下面是聲明數(shù)組變量的語法:
int[] arr;//聲明數(shù)組,告訴計(jì)算機(jī)我要存儲(chǔ)一組整數(shù)(推薦) 或 //int arr[];
int x1,x2,x3;//聲明了3個(gè)int類型的變量 int [] n1,n2,n3;//聲明了3個(gè)數(shù)組 int num1 [],num2,num3;//聲明了一個(gè)int類型的數(shù)組num1,兩個(gè)Int類型的變量。
arr = new int[6];//創(chuàng)建一個(gè)數(shù)組,計(jì)算機(jī)在內(nèi)存中分配6個(gè)空間,并初始化
數(shù)組的元素是通過索引訪問的。數(shù)組索引從 0 開始,所以索引值從 0 到 arr.length-1。
//動(dòng)態(tài)初始化:我們制定長度,系統(tǒng)賦值。 int[] arr = new int[5];//0 //初始值 //整數(shù):0 小數(shù):0.0 布爾:false char:\0000 //String:null //靜態(tài)初始化:我們賦值,系統(tǒng)分配長度(arr2.length) int[] arr2 = {11,22,33};
arr[2]=33;
是作為構(gòu)思算法的輔助工具,不是完全的數(shù)據(jù)存儲(chǔ)工具。是插入和刪除操作被限制在表的線性表。
只能從棧頂入棧,也只能從棧頂出站
是一種后進(jìn)先出的結(jié)構(gòu)
普通for循環(huán)
public class TestArray { public static void main(String[] args) { double[] myList = {1.9, 2.9, 3.4, 3.5}; // 打印所有數(shù)組元素 for (int i = 0; i < myList.length; i++) { System.out.println(myList[i] + " "); } // 計(jì)算所有元素的總和 double total = 0; for (int i = 0; i < myList.length; i++) { total += myList[i]; } System.out.println("Total is " + total); // 查找最大元素 double max = myList[0]; for (int i = 1; i < myList.length; i++) { if (myList[i] > max) max = myList[i]; } System.out.println("Max is " + max); } }
增強(qiáng)for循環(huán)
public class TestArray { public static void main(String[] args) { double[] myList = {1.9, 2.9, 3.4, 3.5}; // 打印所有數(shù)組元素 for (double element: myList) { System.out.println(element); } } }
增強(qiáng)for循環(huán)的特點(diǎn):
【1】簡潔
【2】不能制定范圍訪問,只能訪問全部
【3】不能反轉(zhuǎn)輸出,只能正序訪問
【4】不能修改數(shù)組元素的值
package day4; public class Demo12 { public static void main(String[] args) { // 冒泡排序 int[] arr = {34,1,78,9,43}; int temp; for(int i = 0 ; i < arr.length-1;i++) {//輪 for(int j = 0; j < arr.length-1-i; j++) {//次 if(arr[j] > arr[j+1]) { temp = arr[j]; arr[j]= arr[j + 1]; arr[j + 1] = temp; } } } for(int n: arr) { System.out.println(n); } } }
package day4; import java.util.Arrays; public class Demo13 { public static void main(String[] args) { // 選擇排序 int [] arr = {5,12,3,78,345}; int temp; for(int i = 0; i < arr.length-1; i++) {//位置 for(int j = i + 1; j < arr.length; j++) { if(arr[i] > arr[j]) { temp = arr[i]; arr[i] = arr[j]; arr[j] = temp; } } } for(int n:arr) { System.out.println(n); } // System.out.println(Arrays.toString(arr)); } }
public class ArrayTest { public static void main(String[] args) { // TODO Auto-generated method stub int[] arr = {4,6,8,33,66,44,99,54}; int num=searchKey(arr,66); System.out.println(num); } //查找一個(gè)元素在數(shù)組中的第一次出現(xiàn)的位置 public static int searchKey(int[] arr,int key) { for(int i=0;i
public class binarySearch { public static void main(String[] args) { int[] arr = {9,12,15,24,36,41,59,68}; int num =searchArray(arr,12); System.out.println(num); } //二分查找。前天:數(shù)組必須是有序的。 /* * 思路: * 1.通過角標(biāo)先獲取中間角標(biāo)上的元素 * 2.讓該元素和要找的數(shù)據(jù)比較。 * 3.如果要找的數(shù)大了,縮小范圍,要找的范圍應(yīng)該是 中間的角標(biāo)+1---尾角標(biāo) * 如果要找的數(shù)效率,要找的范圍 頭角標(biāo)---中間角標(biāo)-1。 * 4.不斷如此重復(fù),就可以找到元素對(duì)應(yīng)的角標(biāo)。 * */ public static int searchArray(int[] arr,int key) { int max,min,mid; min = 0; max = arr.length-1; mid = (min+max)>>1; while(arr[mid]!=key) { if(key > arr[mid]) { min = mid + 1; }else{ max = mid - 1; } //判斷元素是否存在。 if(max>1; } return mid; } }
public class ArrayTest1 { public static void main(String[] args) { int[] arr = {9,12,15,24,36,41,59,68}; int num =binarySearch(arr,44); System.out.println(num); } //二分查找。前天:數(shù)組必須是有序的。 /* * 思路: * 1.通過角標(biāo)先獲取中間角標(biāo)上的元素 * 2.讓該元素和要找的數(shù)據(jù)比較。 * 3.如果要找的數(shù)大了,縮小范圍,要找的范圍應(yīng)該是 中間的角標(biāo)+1---尾角標(biāo) * 如果要找的數(shù)效率,要找的范圍 頭角標(biāo)---中間角標(biāo)-1。 * 4.不斷如此重復(fù),就可以找到元素對(duì)應(yīng)的角標(biāo)。 * */ public static int binarySearch(int[] arr,int key) { //定義單個(gè)變量,記錄頭角標(biāo),尾角標(biāo),中間角標(biāo) int max,min,mid; min = 0; max = arr.length-1; while(min<=max) { mid = (min+max)>>1; if(key > arr[mid]) { min = mid + 1; }else if(key < arr[mid]) { max = mid - 1; }else { return mid; } } return -1; } }
package cn.java.study; import java.util.Arrays; public class Demo5 { public static void main(String[] args) { int[] arr1 = {1,4,6,83,45}; int[] arr2 = new int[arr1.length]; // 源數(shù)組 源數(shù)組起始位置 目標(biāo)數(shù)組 目標(biāo)數(shù)組起始位置 復(fù)制長度 System.arraycopy(arr1, 1, arr2, 2, 3); System.out.println(Arrays.toString(arr2)); } }
package cn.java.study; //工具類 import java.util.Arrays; public class Demo5 { public static void main(String[] args) { //Arrays int[] arr = {1,4,7,434,232,55}; //將數(shù)組轉(zhuǎn)換成字符串 System.out.println(Arrays.toString(arr)); //對(duì)數(shù)組進(jìn)行升序排序 Arrays.sort(arr); System.out.println(Arrays.toString(arr)); //排序數(shù)組名 排序數(shù)組元素開始位置 排序數(shù)組元素結(jié)束位置(實(shí)際上,取到終止位置減一)[起始位置,終止位置) Arrays.sort(arr,2,4); System.out.println(Arrays.toString(arr)); //多核處理器下并行操作使用 Arrays.parallelSort(arr); //二分查找下標(biāo),數(shù)組 查找的數(shù)字,返回的是插入點(diǎn),沒有的話返回的是負(fù)的插入點(diǎn)減一的值 System.out.println(Arrays.binarySearch(arr, 8)); //數(shù)組比較:元素的個(gè)數(shù)和對(duì)應(yīng)位置的數(shù)組元素相同 int[] arr1 = {1,2,5}; int[] arr2 = {1,2,5}; System.out.println(Arrays.equals(arr1, arr2)); //數(shù)組的填充,將數(shù)組中所有的元素替換為666 Arrays.fill(arr, 666); System.out.println(Arrays.toString(arr)); //數(shù)組的復(fù)制,返回的是一個(gè)數(shù)組, (要復(fù)制的數(shù)組,幾個(gè)元素) int[] arr3 = Arrays.copyOf(arr1, 2); System.out.println(Arrays.toString(arr3)); } }
格式1:
int[][] arr = new int[3][2];
定義了名稱為arr的二位數(shù)組
二維數(shù)組中有3個(gè)一維數(shù)組
每一個(gè)一維數(shù)組中有2個(gè)元素
一維數(shù)組的名稱分別為arr[0],arr[1],arr[2]
給第一個(gè)一維數(shù)組1角標(biāo)位賦值為666的寫法是:arr[0][1] = 666;
System.out.println(arr); // [[Ie6f7d2二位數(shù)組實(shí)體 e6f7d2是哈希值,[是數(shù)組,[[二位數(shù)組
格式2:
int[][] arr = new int[3][]; arr[0] = new int[3]; arr[1] = new int[1]; arr[2] = new int[2];
關(guān)于“Java數(shù)組常見應(yīng)用的示例分析”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。
當(dāng)前標(biāo)題:Java數(shù)組常見應(yīng)用的示例分析
網(wǎng)站網(wǎng)址:http://aaarwkj.com/article14/igeide.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供電子商務(wù)、品牌網(wǎng)站建設(shè)、定制開發(fā)、商城網(wǎng)站、網(wǎng)站改版、ChatGPT
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)