数组扩展(Java)
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)的更多相关文章
- Java数组扩展
Java中,数组初始化后如何扩展数组? 示例 以下示例显示如何在创建新并初始化数组后扩展数组. package com.yiibai; public class ExtendingArray { pu ...
- js 判断数组包含某值的方法 和 javascript数组扩展indexOf()方法
var questionId = []; var anSwerIdValue = []; ////javascript数组扩展indexOf()方法 Array.prototype.indexOf ...
- javascript中的数组扩展(一)
javascript中的数组扩展(一) 随着学习的深入,发现需要学习的关于数组的内容也越来越多,后面将会慢慢归纳,有的是对前面的强化,有些则是关于前面的补充. 一.数组的本质 数组是按照次序排 ...
- ES6数组扩展
前面的话 数组是一种基础的JS对象,随着时间推进,JS中的其他部分一直在演进,而直到ES5标准才为数组对象引入一些新方法来简化使用.ES6标准继续改进数组,添加了很多新功能.本文将详细介绍ES6数组扩 ...
- es6基础(6)--数组扩展
//数组扩展 { let arr=Array.of(3,4,6,7,9,11);//可以是空 console.log('arr=',arr);//[3,4,6,7,9,11] } { //Array. ...
- ES6入门教程---数值扩展和数组扩展
1.数值扩展 var num = 0b11; console.log(num);3 var num = 0o11;console.log(num);9 var num = 1.234; console ...
- NOJ——1669xor的难题(详细的树状数组扩展—异或求和)
[1669] xor的难题 时间限制: 1000 ms 内存限制: 65535 K 问题描述 最近Alex学长有个问题被困扰了很久,就是有同学给他n个数,然后给你m个查询,然后每个查询给你l和r(左下 ...
- 作业2-浅谈数组求和java实验
这次作业呢,我是用java来写的,虽然java只是自己假期里看的一点点,但是人总是要接触新事物的,应该不断向前. 说明:这次作业有一个遗憾,就是我花了一个下午真真 ...
- 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 ...
- ES6数组扩展运算符
1 扩展运算符的运用 (1)复制数组 数组是复合的数据类型,直接复制的话,只是复制了指向底层数据机构的指针,而不是克隆一个全新的数组; const a1=[1,2]; const a2= a1; a2 ...
随机推荐
- VS2019编译Qt4.8.7
下载4.8.7源码Index of /archive/qt/4.8/4.8.7 复制mkspecs\win32-msvc2015到mkspecs\win32-msvc2019 修改qmake.conf ...
- Java 查找Panel 里的某个组件 比如 按钮
遇到到一个需求,需要获取界面里的一个按钮,但是这个按钮是封装的父类嵌入的,知道label 的值. 写了一个递归获取它 1 private JButton LookupTheButton(Compone ...
- MAC 不带XIB新建ViewController
- (void)loadView{ NSView *view = [[NSView alloc]init]; self.view = view; } MAC 开发的小伙伴
- springboot返回前端对象null转为空字符串
1 2 import com.fasterxml.jackson.core.JsonGenerator; 3 import com.fasterxml.jackson.core.JsonProcess ...
- SCI论文写作技巧-introduction和related works
introduction怎么写 a)背景介绍,现状(介绍别人研究),存在问题,怎样解决,我的做法,有何亮点 b)研究背景和重要性.引出该领域科研空白.点题-指出本文的研究课题.概述文章的核心方法论和主 ...
- es 部署 进程、文件数 配置
1. /etc/security/limits.conf elasticsearch soft nofile 65536 elasticsearch hard nofile 65536 elasti ...
- Filter Pattern 2 (dubbo的实现方式)
前一篇FilterPattern的范式,基本和Tomcat实现的filter chain是一样的: 这里介绍一下我看完dubbo关于Filter Pattern的实现思路,自己抽象出来的代码,以及理解 ...
- 使用@RequestBody注解接收的实体类中的某些参数为null
原因 postman调试接口 为null的参数命名不符合"驼峰法",类似实体类A的属性 cEnterpriseId ,这种命名是不规范的 和lombook的@Data注解有关 用p ...
- C++ primer笔记 -变量和基本类型
由于头文件会被包含在多个源文件中,所以不应该含有变量或者函数的定义.但又三个列外: 1.头文件可以定义类 2.值在编译时就已经知道的const对象(const对象默认为定义它的文件的局部变量,即在.c ...
- RestTemplate 连接池最大链接数
原文链接:https://www.cnblogs.com/x-x-736880382/p/11591906.html 以前我们项目都是基于Apache HttpClient 连接池进行web 接口调用 ...