Java编程基础——数组和二维数组
Java编程基础——数组和二维数组
摘要:本文主要对数组和二维数组进行简要介绍。
数组
定义
数组可以理解成保存一组数的容器,而变量可以理解为保存一个数的容器。
数组是一种引用类型,用于保存一组相同类型的数据。
数组定义的类型可以为任意类型,意思是我们可以定义int类型的数组,也可以定义String类型的数组,或其他任何类型的数组。
数组实际在内存的存储和基本类型不同,实际上是在堆中申请空间保存一组数,栈中只是有一个地址的引用。
声明数组
语法:
类型[] 数组名;
类型 数组名[];
举例:
int[] sum;
int color[];
说明:
此时只是声明了一个数组变量,并没有在内存中开辟空间。
开辟空间
语法:
数组名 = new 类型[长度];
举例:
sum = new int[5];
说明:
数组开辟空间时,必须要设置开辟的空间长度。
这时会根据类型对数组里的数据设置默认值。
数组赋值
语法:
数组名[下标] = 值;
举例:
sum[0] = 10;
说明:
在对数组进行赋值时,注意下标不要超过数组的长度范围,否则会产生错误。
使用数组
语法:
数组名[下标]
举例:
System.out.println(sum[0]);
说明:
同样需要注意下标不要超过数组的长度范围。
其他赋值方式
除了上面通过下标赋值,还可以在声明时开辟空间并赋值,或者在开辟空间时赋值。
语法:
数组名 = new 类型[]{值, 值};
类型[] 数组名 = {值, 值};
举例:
int[] sum = {1, 2};
sum = new int[]{1, 2, 3};
说明:
这两种方式都需要在确定数组大小和值的内容的时候使用。
在开辟空间时赋值,不需要在中括号里面填写数组长度。
注意
数组不赋值也有默认值。
数组中每个元素的赋值和访问都是通过“数组名[下标]”实现的,不能直接使用数组名。
“数组名.length”代表的是数组的长度,经常用在循环中,提高代码的维护性。
数组的下标从 0 ~ 数组名.length - 1 ,如果不是这个范围,会导致一个数组下标越界的异常:ArrayIndexOutOfBoundsException。
数组没有开辟空间,直接使用,会导致一个空指针异常:NullPointerException。
进阶使用
数组的复制
◆ 引用类型的赋值:复制的是一个地址号,二者共同引用一个地址,其中一个对数组做了更改,都会影响另一个。
◆ 基本类型的赋值:复制的是数值内容,实际上是一个备份,其中一个对它更改,不会影响另一个。
复制引用地址:
复制的是一个地址号,二者共同引用一个地址,其中一个对数组做了更改,都会影响另一个。
int[] a1 = {1, 2, 3};
int[] a2;
a2 = a1;
System.out.println(a2[0]);
a1[0] = 100;
System.out.println(a2[0]);
结果:
1
100
复制数组数据:
int[] a1={1, 7, 8};
int[] a2 = new int[a1.length];
for (int i = 0; i < a1.length; i++) {
a2[i] = a1[i];
}
System.out.println(a2[0]);
a2[1]=100;
System.out.println(a2[0]);
结果:
1
1
数组的排序
int[] nums = {1, 9, 3, 5, 2, 8, 4};
for(int i = 0; i < nums.length - 1; i++) {// 控制轮数
for(int j = 0; j < nums.length - 1 - i; j++) {
if (nums[j] < nums[j + 1]) {// 交换
int temp = nums[j];
nums[j] = nums[j + 1];
nums[j + 1] = temp;
}
}
}
数组的倒置
int[] nums = {1, 9, 3, 5, 2, 8, 4};
for(int i = 0; i < nums.length / 2; i++) {
int temp = nums[i];
nums[i] = nums[nums.length - 1 - i];
nums[nums.length - 1 - i] = temp;
}
工具类
排序: Arrays.sort(nums);
填充: Arrays.fill(nums, 1);
转成字符串以便打印: Arrays.toString(nums);
比较: Arrays.equals(a1, a2);
二维数组
定义
二维数组可以看做是一个数组,里面存放的元素是一维数组。
声明数组
int[][] nums;
int nums[][];
int[] nums[];
开辟空间
nums = new int[3][];// 行固定,列不固定。
nums = new int[3][2];// 行固定,列固定。
数组赋值
动态初始化,使用时赋值,需要指明行和列:
nums[0][1] = 1;
静态初始化,声明时赋值,不必也不能指明行和列,否则会提示错误:
int[][] nums = new int[][]{{1}, {9, 3, 5, 2}, {7, 6}};
int[][] nums = {{1}, {9, 3, 5, 2}, {7, 6}};
注意
如果在动态初始化时明确了二维数组的行数和列数,那么一维数组的长度就是固定的列数。
如果在动态初始化时仅仅明确了行数,或者通过静态初始化赋值,那么一维数组可以有不同的长度。
数组排序
冒泡排序
思路
属于交换排序。
从第一个元素开始,比较两个相邻的元素,如果两个元素位置不正确,则进行交换,否则继续比较下面相邻的两个元素。
代码
public void test() {
int[] arr = new int[]{, , , , };
int len = arr.length;
for (int i = ; i < len - ; i++) {
for (int j = ; j < len - i - ; j++) {
if (arr[j] > arr[j + ]) {
int temp = arr[j];
arr[j] = arr[j + ];
arr[j + ] = temp;
}
}
}
for (int i = ; i < arr.length; i++) {
System.out.println(arr[i]);
}
}
快速排序
思路
属于交换排序。
任取序列的某个元素作为界点,将序列分为两个子序列,左子序列的元素小于界点,右子序列的元素大于界点,然后递归每个子序列,直到每个子序列只有一个元素。
代码
public void test() {
int[] arr = new int[]{, , , , , , };
sort(, arr.length - , arr);
for (int i = ; i < arr.length; i++) {
System.out.println(arr[i]);
}
}
public void sort(int left, int right, int[] arr){
int l = left;
int r = right;
int pivot = arr[(left + right)/];//找中间值
int temp = ;
while(l < r){
while(arr[l] < pivot) l++;
while(arr[r] > pivot) r--;
if(l >= r) break;
temp = arr[l];
arr[l] = arr[r];
arr[r] = temp;
if(arr[l] == pivot) --r;
if(arr[r] == pivot) ++l;
}
if(l == r){
l++;
r--;
}
if(left < r) sort(left, r, arr);
if(right > l) sort(l, right, arr);
}
直接选择排序
思路
属于选择排序。
每次都选取最小值放在起始位上,一共通过n-1次。
代码
public void test() {
int[] arr = new int[]{, , , , , , };
for (int i = ; i < arr.length - ; i++) {
int index = i;
for (int j = i + ; j < arr.length; j++) {
if (arr[index] > arr[j]) {
index = j;
}
}
int temp = arr[i];
arr[i] = arr[index];
arr[index] = temp;
}
for (int i = ; i < arr.length; i++) {
System.out.println(arr[i]);
}
}
Java编程基础——数组和二维数组的更多相关文章
- java基础知识点补充---二维数组
#java基础知识点补充---二维数组 首先定义一个二维数组 int[][] ns={ {1,2,3,4}, {5,6,7,8}, {9,10,11,12}, {13,14,15,16} }; 实现遍 ...
- 062 01 Android 零基础入门 01 Java基础语法 07 Java二维数组 01 二维数组应用
062 01 Android 零基础入门 01 Java基础语法 07 Java二维数组 01 二维数组应用 本文知识点:二维数组应用 二维数组的声明和创建 ? 出现空指针异常 数组的名字指向数组的第 ...
- java基础5 (一维)数组和二维数组
本文知识点(目录): 一维数组(一维数组的概念.优点.格式.定义.初始化.遍历.常见异常.内存分析以及常见操作(找最大值.选择排序.冒泡排序等等)) 二维数组(二维数组的遍历.排序.查找.定义. ...
- Java知识系统回顾整理01基础06数组06二维数组
一.一维数组和二维数组 这是一个一维数组, 里面的每一个元素,都是一个基本类型int int a[] =new int[]{1,2,3,4,5}; 这是一个二维数组,里面的每一个元素,都是一个一维数组 ...
- java - day005 - 数组工具类, 数组复制,二维数组,变量,方法, 面向对象
1. java.util.Arrays 数组工具类 Arrays.toString (数组) 数组值链接字符串 Arrays.sort(数组) 基本类型: 优化的快速排序 引用类型: 优化的合 ...
- Java数组之二维数组
Java中除了一维数组外,还有二维数组,三维数组等多维数组.本文以介绍二维数组来了解多维数组. 1.二维数组的基础 二维数组的定义:二维数组就是数组的数组,数组里的元素也是数组. 二维数组表示行列二维 ...
- JAVA描述算法和数据结构(01):稀疏数组和二维数组转换
本文源码:GitHub·点这里 || GitEE·点这里 一.基本简介 1.基础概念 在矩阵中,若数值为0的元素数目远远多于非0元素的数目,并且非0元素分布没有规律时,则称该矩阵为稀疏矩阵:与之相反, ...
- 一维数组、二维数组——Java
一. 一维数组 1. 数组是相同类型数据的有序集合 相同类型的若干个数据,按照一定先后次序排列组合而成 每个数组元素可以通过一个下标来访问它们 其中,每一个数据称作一个数组元素 2. 数组特点: 其 ...
- android JNI 一维数组、二维数组的访问与使用
在JNI中访问JAVA类中的整型.浮点型.字符型的数据比较简单,举一个简单的例子,如下: //得到类名 jclass cls = (*env)->GetObjectClass(env, obj) ...
随机推荐
- 工具类Base64Util
在和服务器交互的过程中,有时候我们需要把图片编码成base64字符串传输,记录一下工具类 import android.graphics.Bitmap; import android.graphics ...
- 【LeetCode】437. 路径总和 III
437. 路径总和 III 给定一个二叉树,它的每个结点都存放着一个整数值. 找出路径和等于给定数值的路径总数. 路径不需要从根节点开始,也不需要在叶子节点结束,但是路径方向必须是向下的(只能从父节点 ...
- 从立创EDA,Gratipay看中文编程开发环境和推广运营的一个趋势
前不久听说立创EDA,对比之前的讨论: 适合中文用户的编程语言和IDE, 侧重于现有语言/IDE不具备的特性 · Issue #11 · program-in-chinese/overview,觉得颇 ...
- [b0006] Spark 2.0.1 伪分布式搭建练手
环境: 已经安装好: hadoop 2.6.4 yarn 参考: [b0001] 伪分布式 hadoop 2.6.4 准备: spark-2.0.1-bin-hadoop2.6.tgz 下载地址: ...
- bayaim_linux_configure_oracle
---------------------------bayaim_linux_install_oracle_11g--2.0------------------------------------- ...
- CPU 架构SMP/NUMA,调优
CPU 架构SMP/NUMA,调优 SMP:全称是"对称多处理"(Symmetrical Multi-Processing)技术 . 是指在一个计算机上汇集了一组处理器(多CPU) ...
- lua 10 迭代器
转自:http://www.runoob.com/lua/lua-iterators.html 迭代器(iterator)是一种对象,它能够用来遍历标准模板库容器中的部分或全部元素,每个迭代器对象代表 ...
- 《阿里B2B技术架构演进详解》----阅读
B2B(Business To Business)是指一个市场的领域的一种,是企业对企业之间的营销关系.先来总结一下阿里B2B共分为三个阶段: 第一阶段,建立信息网站提供信息和营销服务平台,让买家更加 ...
- luoguP5227 [AHOI2013]连通图(线性基做法)
题意 神仙哈希做法. 随便找个生成树,给每个非树边赋一个值,树边的值为所有覆盖它的边的值得异或和. 删去边集使得图不联通当且即当边集存在一个子集异或和为0,可以用线性基. 证明的话好像画个图挺显然的 ...
- CF-378 B.Semifinals
题目意思:有n个参赛者,他们都需要参加两场半决赛.第一场半决赛的成绩依次是a1, a2, ..., an,分别对应第1-第n个人的成绩.第二场则是b1, b2, ..., bn.其中这两个序列都是以递 ...