小白艰苦学习之路(记录学习历程——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的主要内容,如果未能解决你的问题,请参考以下文章