Arrays类、冒泡排序、稀疏数组
Arrays类
package base;
import java.util.Arrays;
/**
* Arrays类
*/
public class ArraysTest {
public static void main(String[] args) {
int [] a = {1,2,3,4543,3,422,45,24,33};
System.out.println("数组地址值为:"+Arrays.asList(a));
System.out.println("数组具体值为:"+Arrays.toString(a));
Arrays.sort(a);
System.out.println("排序后的具体值为:"+Arrays.toString(a));
System.out.println("打印自定义的Arrays类toString方法,结果如下:");
printA(a);
System.out.println();
//Arrays.fill(a,0);//指定元素被填充
//System.out.println(Arrays.toString(a));
Arrays.fill(a,2,4,0);
System.out.println("对应位置填充0后得到的数组为:"+Arrays.toString(a));
}
/**
* 手写to_string方法
* @param a
*/
public static void printA(int [] a){
for (int i = 0; i <a.length ; i++) {
if(i==0){
System.out.printf("[");
}
if(i==a.length-1){
System.out.print(a[i]+"] ");
}else{
System.out.print(a[i]+", ");
}
}
}
}
输出结果如下所示:
数组地址值为:[[I@4554617c]
数组具体值为:[1, 2, 3, 4543, 3, 422, 45, 24, 33]
排序后的具体值为:[1, 2, 3, 3, 24, 33, 45, 422, 4543]
打印自定义的Arrays类toString方法,结果如下:
[1, 2, 3, 3, 24, 33, 45, 422, 4543]
对应位置填充0后得到的数组为:[1, 2, 0, 0, 24, 33, 45, 422, 4543]
冒泡排序
package base;
import java.util.Arrays;
/**
*
* 冒泡排序
*
* 1.在数组中,比较相邻的两个元素,要是第一个元素比第二个元素大,就交换位置
* 2.每次比较都会产生一个较大和较小的数字
* 3.下一轮就可以少一次排序
* 4.依次循环,直到结束
*/
public class Demo04 {
public static void main(String[] args) {
int [] array = {1,223,23,45,3,24,533,3};
System.out.println(Arrays.toString(sort(array)));
}
public static int [] sort(int [] array){
int temp = 0;
//外层循环:判断我们要走多少次
for (int i = 0; i <array.length-1 ; i++) {
//内层循环:比较判断两个数,如果第一个数比第二个数大,就交换位置
for (int j = 0; j <array.length-1-i ; j++) {
temp = array[j];
if(array[j+1]>array[j]){
temp = array[j];
array[j] = array[j+1];
array[j+1] = temp;
}
}
}
return array;
}
}
输出结果如下所示:
[533, 223, 45, 24, 23, 3, 3, 1]
稀疏数组
当一个数组大部分元素为0,或者为同一值的数组时,可以用稀疏数组来保存该数组,起到压缩的作用;
稀疏数组的处理方式是:记录数组一共有几行几列,有多少个不同值;
把具有不同值的元素和行列及值记录在小规模的数组中,从而缩小程序的规模;
需求:编写五子棋游戏中,有存盘退出和续上盘的功能;
因为该二维数组的很多默认值为0,因此记录了很多没有意义的数据;
解决:稀疏数组;
package base;
import java.util.Arrays;
/**
* 稀疏数组
*/
public class Demo05 {
public static void main(String[] args) {
//创建一个二维数组,11行11列,白棋为0,黑棋为1
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();
}
//创建为稀疏数组
//保存有效数字
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);
System.out.println("-----------------");
//创建一个稀疏数组
int [][] array2 = new int [sum+1][3];
array2[0][0] = 11;
array2[0][1] = 11;
array2[0][2] = sum;
//便利二维数组,把非0的值存到此数组中
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]);
}
System.out.println("-----------------");
//1.还原稀疏数组
int[][]array3 = new int [array2[0][0]][array2[0][1]];
//2.给其中元素还原他的值
for (int i = 1; i < array2.length ; i++) {
array3[array2[i][0]][array2[i][1]] = array2[i][2];
}
//2.打印
System.out.println("还原的数组为:");
for (int [] ints : array3) {
for (int anInt: ints) {
System.out.print(anInt + "\t");
}
System.out.println();
}
}
}
输出结果如下所示:
原始数组为:
0 0 0 0 0 0 0 0 0 0 0
0 0 1 0 0 0 0 0 0 0 0
0 0 0 2 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
有效值个数为:2
输出稀疏数组:
11 11 2
1 2 1
2 3 2
还原的数组为:
0 0 0 0 0 0 0 0 0 0 0
0 0 1 0 0 0 0 0 0 0 0
0 0 0 2 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0