小白艰苦学习之路(记录学习历程——Java篇)Day6
Posted 花子柒
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了小白艰苦学习之路(记录学习历程——Java篇)Day6相关的知识,希望对你有一定的参考价值。
Day6
数组概述
- 数组是相同类型数据的有序集合
- 数组描述的是相同类型的若干个数据,安札一定的先后次序排列组合而成
- 其中,每一个数据称作一个数组元素,每个数组元素可以通过一个下标来访问它们
数组声明创建
public class Test1
//变量的类型 变量的名字 = 变量的值
//数组类型
public static void main(String[] args)
int[] nums;//1.声明了一个数组
//int nums1[]; //声明了一个数组 一般不用
nums = new int[10];//2.创建了一个数组,这里可以存放10个int类型的数字
// int[] nus = new int[5];//简易创建方法
//3.给数组元素赋值
nums[0] = 1;
nums[1] = 2;
nums[2] = 3;
nums[3] = 4;
nums[4] = 5;
nums[5] = 6;
nums[6] = 7;
nums[7] = 8;
nums[8] = 9;
nums[9] = 10;
//计算所有元素的和
int sum = 0;
for (int i = 0; i < nums.length; i++)
sum = nums[i] + sum;
System.out.println("总和为:"+sum);
效果运行图
数组的四个基本特点
三种初始化以及内存分析
内存分析
三种初始化
public class Test2
public static void main(String[] args)
//静态初始化:创建+赋值
int[] a = 1,2,3;
//动态初始化:包含默认初始化
int[] b = new int[5];
b[0] = 1;
下标越界以及小结
数组的四个基本特点
数组边界
数组的使用
- 普通用法
public class Test3
public static void main(String[] args)
int[] arrays = 1,2,3,4,5;
//打印全部数组元素
for (int i = 0; i < arrays.length; i++)
System.out.println(arrays[i]);
System.out.println("===================");
//计算所有元素的和
int sum = arrays[0];
for (int i = 0; i < arrays.length; i++)
sum += arrays[i];
System.out.println("sum="+sum);
System.out.println("===================");
//查找最大元素
int max = arrays[0];
for (int i = 1; i < arrays.length; i++)
if (max < arrays[i])
max = arrays[i];
System.out.println("max="+max);
效果运行图
-
For-Each循环
-
数组作方法入参
-
数组作返回值
public class Test4
public static void main(String[] args)
int[] arrays = 1,2,3,4,5;
/*
//for-each循环
//数组每一个元素 //数组 JDK1.5省去了下标
for (int array : arrays)
System.out.println(arrays);
*/
int[] reverse = reverse(arrays);
printArray(reverse);
//打印数组元素
public static void printArray(int[] arrays)
for (int i = 0; i < arrays.length; i++)
System.out.print(arrays[i]+" ");
//反转数组元素
public static int[] reverse(int[] arrays)
int[] result = new int[arrays.length];
//反转操作
for (int i = 0,j = arrays.length-1; i < arrays.length; i++,j--)
result[j] = arrays[i];
return result;
效果运行图
多维数组
public class Test5
public static void main(String[] args)
//[4][2]
/*
1,2 array[0]
2,3 array[1]
3,4 array[2]
4,5 array[3]
*/
int[][] array = 1,2,2,3,3,4,4,5;
//打印二维数组的每个元素
for (int i = 0; i < array.length; i++)
for (int j = 0; j < array[i].length; j++)
System.out.print(array[i][j]+" ");
System.out.print("/");
System.out.println();
System.out.println("============");
printArray(array[0]);
//打印数组元素
public static void printArray(int[] array)
for (int i = 0; i < array.length; i++)
System.out.println(array[i]+" ");
运行效果图
Arrays类
import java.util.Arrays;
import java.util.IllegalFormatCodePointException;
public class Test6
public static void main(String[] args)
int[] a = 21,243,5435,1,3435;
System.out.println(a);//[I@2d98a335
//打印数组元素 Array.toString
System.out.println(Arrays.toString(a));//[21, 243, 5435, 1, 3435]
//调用printArray打印数组元素
printArray(a);
System.out.println("========================");
//数组排序打印
Arrays.sort(a);
System.out.println(Arrays.toString(a));
System.out.println("========================");
//数组填充
// Arrays.fill(a,0);//全部填充
// System.out.println(Arrays.toString(a));
Arrays.fill(a,2,4,0);//2-4之间进行填充
System.out.println(Arrays.toString(a));
//打印数组元素
public static void printArray(int[] a)
for (int i = 0; i < a.length; i++)
if (i == 0)
System.out.print("["+a[0]+", ");
else if(i == a.length-1)
System.out.print(+a[i]+"]");
else
System.out.print(a[i]+", ");
System.out.println();
效果运行图
冒泡排序
【两两进行比较,将最小的数移到第一位】
import java.util.Arrays;
public class Test7
public static void main(String[] args)
int[] a = 4,2,8,10,41,1;
sort(a);//调用完我们自己写的排序方法后,返回一个排序后的数组
System.out.println(Arrays.toString(sort(a)));
/*
冒泡排序
1.比较数组中两个相邻元素,如果第一个数比第二个数大,我们就交换它的位置
2.每一次比较,都会产生一个最大,或者最小的数字
3.下一轮则可以少一次排序
4.依次循环,直到结束
*/
public static int[] sort(int a[])
//外层循环 决定循环走几次
for (int i = 0; i < a.length-1; i++)
boolean flag = false;//通过flag标识位减少没有意义的比较
//内才能够循环 比较判断两个数,如果第一个数比第二个数大,则交换位置
for (int j = 0; j < a.length-1-i;j++)
if (a[j]>a[j+1])
int temp = 0;//临时变量
temp = a[j];
a[j] = a[j+1];
a[j+1] = temp;
flag = true;
if (flag = false)
break;
return a;
效果运行图
稀疏数组(数据结构)
稀疏数组的介绍
import java.util.Arrays;
public class Test8
public static void main(String[] args)
//创建一个二维数组 11*11 其中 0:没有棋子 1:黑棋 2:白棋
int[] [] array1 = new int[11][11];
array1[1][2] = 1;
array1[2][3] = 2;
//输出原始的数组
System.out.println("输出原始数组:");
for (int[] ints : array1)
for (int anInt : ints)
System.out.print(anInt+"\\t");
System.out.println();
//转换为稀疏数组
System.out.println("转换为稀疏数组");
//获取有效值的个数
int sum = 0;
for (int i = 0; i < 11; i++)
for (int j = 0; j < 11; j++)
if (array1[i][j] != 0)
sum++;
System.out.println("有效值的个数:"+sum);
//创建一个稀疏数组
int[][] array2 = new int[sum+1][3];
array2[0][0] = 11;
array2[0][1] = 11;
array2[0][2] = sum;
//便利二位是数组,将非零的值,存放稀疏数组中
int count = 0;
for (int i = 0; i < array1.length; i++)
for (int j = 0; j < array1[i].length; j++)
if (array1[i][j] != 0)
count++;
array2[count][0] = i;
array2[count][1] = j;
array2[count][2] = array1[i][j];
//输出稀疏数组
System.out.println("稀疏数组:");
for (int i = 0; i < array2.length; i++)
System.out.println(array2[i][0]+"\\t"+array2[i][1]+"\\t"+array2[i][2]+"\\t");
以上是关于小白艰苦学习之路(记录学习历程——Java篇)Day6的主要内容,如果未能解决你的问题,请参考以下文章