Arrays类

基本介绍

  • 数组的工具类java.util.Arrays
  • 由于数组本身中没有什么方法可供我们调用,但API中提供了一个工具类Arrays供我们使用,从而可以对数据对象进行一些基本操作
  • 查看jdk帮助文档
  • Arrays类中的方法都是static修饰的静态方法,在使用的时候可以直接使用类名进行调用,而不用使用对象来调用(是不用不是不能)
  • 常用功能:a.给数组赋值通过fill方法;b.对数组排序通过sort方法按升序;c.比较数组通过equals方法比较数组中元素值是否相等

运用实例

import java.util.Arrays;
public class Array {
public static void main(String[] args) {
int[] a={4,5226,846,57,569,336,5,2,1};
System.out.println(a);//输出:[I@1540e19d //打印出数组中的元素,调用了Arrays类中的toString方法
System.out.println(Arrays.toString(a));//输出[4, 5226, 846, 57, 569, 336, 5, 2, 1]
//调用PrintArrays方法
PrintArray(a); //数组排序:升序
Arrays.sort(a);
System.out.println(Arrays.toString(a)); //数组填充:把val中的值替换掉数组中的值
Arrays.fill(a,0);
System.out.println(Arrays.toString(a));
//数组填充:把val中的值替换掉数组中2-4(不包含4)之间的元素值
Arrays.fill(a,2,4,0);
System.out.println(Arrays.toString(a));
}
//Arrays类中的方法也是程序员编写的,我们自己也可以编写出来
//定义一个打印数组中的元素的方法
public static int[] PrintArray(int[] a){
for (int i = 0; i < a.length; i++) {
if (i==0){
System.out.print("[");
}
if (i==a.length-1){
System.out.println(a[a.length-1]+"]");
}else{
System.out.print(a[i]+", ");
}
}
return a;
}
}

冒泡排序

基本介绍

  • 冒泡排序是最出名的排序算法之一。总共由八大排序
  • 代码:两成循环,外层冒泡轮数,里层依次比较,江湖中人尽皆知
  • 算法复杂度为O(n^2)

运用实例

import java.util.Arrays;
public class PaiXu {
public static void main(String[] args) {
int[] a={4,85,69,2,47,9546,1};
MaoPao(a);
} //冒泡排序
//1.比较数组中,两个相邻的元素,如果第一个数比第二个数大,我们就交换它们的位置
//2.每一次比较都会产生一个最大的或者最小的数
//3.下一轮则可以少一次排序
//4.依次循环,知道结束
public static void MaoPao(int[] a){
int tep;
boolean flag=false;//通过flag标识位减少没有意义的排序
//外层循环,判断需要走多少次
for (int i = 0; i < a.length-1; i++) {
//里层循环,比较两个相邻的元素,如果第一个数比第二个数大,我们就交换它们的位置
for (int j = 0; j < a.length-1; j++) {
if (a[j]>a[j+1]){
tep=a[j];
a[j]=a[j+1];
a[j+1]=tep;
flag=true;
}
}
if(flag==false){
break;
}
}
System.out.println("冒牌排序输出结果:"+ Arrays.toString(a));
}
}

稀疏数组

  • 当一个数组中大部分元素为0,或者为同一值的数组时,可以使用稀疏数组来保存该数组
  • 稀疏数组的处理方式:
    • 记录数组一共有几行几列,有多少个不同值
    • 把具有不同的值的元素和行列及值记录在一个小规模的数组中,从而缩小程序的规模

运用实例

public class XiShu {
public static void main(String[] args) {
//创建一个二维数组11*11 0:表示没有棋子 1:黑棋 2.白棋
int[][] a=new int[11][11];
a[1][2]=1;
a[2][3]=2; //输出原始数组
System.out.println("输出原始数组");
for (int[] ints : a) {
for (int anInt : ints) {
System.out.print(anInt+"\t");
}
System.out.println();
} //转换为稀疏数组保存
//获取有效值的个数
int count=0;
for (int i = 0; i < 11; i++) {
for (int j = 0; j < 11; j++) {
if (a[i][j]!=0){
count++;
}
}
}
System.out.println("有效值的个数为:"+count);
//创建一个稀疏数组
int[][] b=new int[count+1][3];
b[0][0]=11;
b[0][1]=11;
b[0][2]=count;
//遍历二维数组,将非零的值,存入稀疏数组中
int sum=0;
for (int i = 0; i < a.length; i++) {
for (int j = 0; j < a[i].length; j++) {
if (a[i][j]!=0){
sum++;
b[sum][0]=i;
b[sum][1]=j;
b[sum][2]=a[i][j];
}
}
}
//遍历稀疏数组
System.out.println("输出稀疏数组:");
for (int i = 0; i < b.length; i++) {
for (int j = 0; j < b[i].length; j++) {
System.out.print(b[i][j]+"\t");
}
System.out.println();
} //稀疏数组还原成原来的数组
//读取稀疏数组
int[][] c=new int[b[0][0]][b[0][1]];
//给其中的元素还原它的值
for (int i = 1; i < b.length; i++) {
c[b[i][0]][b[i][1]]=b[i][2];
}
//打印数组
System.out.println("输出原始数组:");
for (int i = 0; i < c.length; i++) {
for (int j = 0; j < c[i].length; j++) {
System.out.print(c[i][j]+"\t");
}
System.out.println();
}
}
}

数组扩展(Java)的更多相关文章

  1. Java数组扩展

    Java中,数组初始化后如何扩展数组? 示例 以下示例显示如何在创建新并初始化数组后扩展数组. package com.yiibai; public class ExtendingArray { pu ...

  2. js 判断数组包含某值的方法 和 javascript数组扩展indexOf()方法

    var  questionId = []; var anSwerIdValue = []; ////javascript数组扩展indexOf()方法 Array.prototype.indexOf ...

  3. javascript中的数组扩展(一)

     javascript中的数组扩展(一) 随着学习的深入,发现需要学习的关于数组的内容也越来越多,后面将会慢慢归纳,有的是对前面的强化,有些则是关于前面的补充. 一.数组的本质    数组是按照次序排 ...

  4. ES6数组扩展

    前面的话 数组是一种基础的JS对象,随着时间推进,JS中的其他部分一直在演进,而直到ES5标准才为数组对象引入一些新方法来简化使用.ES6标准继续改进数组,添加了很多新功能.本文将详细介绍ES6数组扩 ...

  5. es6基础(6)--数组扩展

    //数组扩展 { let arr=Array.of(3,4,6,7,9,11);//可以是空 console.log('arr=',arr);//[3,4,6,7,9,11] } { //Array. ...

  6. ES6入门教程---数值扩展和数组扩展

    1.数值扩展 var num = 0b11; console.log(num);3 var num = 0o11;console.log(num);9 var num = 1.234; console ...

  7. NOJ——1669xor的难题(详细的树状数组扩展—异或求和)

    [1669] xor的难题 时间限制: 1000 ms 内存限制: 65535 K 问题描述 最近Alex学长有个问题被困扰了很久,就是有同学给他n个数,然后给你m个查询,然后每个查询给你l和r(左下 ...

  8. 作业2-浅谈数组求和java实验

              这次作业呢,我是用java来写的,虽然java只是自己假期里看的一点点,但是人总是要接触新事物的,应该不断向前.          说明:这次作业有一个遗憾,就是我花了一个下午真真 ...

  9. java数组、java.lang.String、java.util.Arrays、java.lang.Object的toString()方法和equals()方法详解

    public class Test { public static void main(String[] args) { int[] a = {1, 2, 4, 6}; int[] b = a; in ...

  10. ES6数组扩展运算符

    1 扩展运算符的运用 (1)复制数组 数组是复合的数据类型,直接复制的话,只是复制了指向底层数据机构的指针,而不是克隆一个全新的数组; const a1=[1,2]; const a2= a1; a2 ...

随机推荐

  1. 关于DVWA踩坑

    部署好DVWA开始欢天喜地用起来,结果有个问题,不管怎么设置这个安全等级,都显示为Impossible 原因也很显然 其实我并不太理解为什么这里要放在cookie里面,而且还放了两条. 处理方式也很明 ...

  2. 配置代码片段问题 Invalid characters in string. Control characters must be escaped.

    在使用代码片段时报错 Invalid characters in string. Control characters must be escaped. " somethings" ...

  3. echarts学习

    一.安装与引入 1.安装npm install echarts --save 2.引入import * as echarts from 'echarts';(main.js里全局引入) 二.详细概念 ...

  4. 建筑CAD软件如何设置当前默认层高?

    在绘制CAD建筑图的过程中,必然少不了要对层高进行设置,如果每层的层高都一样,想要调整建筑CAD软件默认当前层高的话该如何设置?本节建筑CAD教程就和小编一起来了解一下浩辰CAD建筑软件中调整默认当前 ...

  5. qgis中的时间格式化函数

    为方便自己查询,尤其是年月日等在不同编程语言直接的差异,就从官方doc中截图放这

  6. Django Rest Frame work 如何使用serializers序列化函数新手教程

    Django Rest Frame work 如何使用serializers序列化       Django Rest Framework提供了serializers模块,用于序列化和反序列化模型实例 ...

  7. gauva cache

    guava 的cache比较好用.    用户使用的对象是LoadingCache, 通过CacheBuilder来创建,通过 CacheLoader来根据key加载数据.而且可以定时刷新缓存(有访问 ...

  8. JavaScript 基础学习(一)

    JavaScript基础学习(一) 一.JavaScript概述 JavaScript的历史 1992年Nombas开发出C-minus-minus(C--)的嵌入式脚本语言(最初绑定在CEnvi软件 ...

  9. unity 变体 随手记

    1 #pragma multi_compile AAA BBB#pragma multi_compile CCC DDDAAA CCCAAA DDDBBB CCCBBB DDD------------ ...

  10. 【ESP32学习】CMake学习

    在之前的博客中提到,ESP-IDF采用的是CMake来构建项目,因此需要学习一下CMake,以对ESP32的开发有更好的把握 参考: Windows下CMake安装教程 从零开始详细介绍CMake C ...