Java基础语法(三)---数组
一、概念
同一种类型数据的集合。简单的来说就是一容器,用来装东西的。
使用数组的好处:可以自动给数组中的元素从0开始编号,方便操作这些元素。
二、一维数组的格式
格式1:元素类型 [ ]数组名 = new 元素类型 [元素个数或数组长度] ;
如: int [] arr = new int [3]; 也可以写成: int arr[] = new int[3];
格式2:元素类型 []数组名 = new 元素类型 [ ]{元素1,元素2,…};
如: int [] arr = new int []{1,2,3,4,5};
还有一种简写的静态初始化格式:如: int [] arr={1,2,3,4,5};
其中:new是用来在堆内存中产生一个容器实体。
数组也被称为引用数据类型。在内存中的分配如下图:
注:1、System.out.println(arr);得到的结果是一个哈希值,也叫地址值。
2、数组在堆内存开辟空间后,就有默认的初始化值。如:int默认0;boolean默认false。
内存小知识:
Java程序在运行时,需要在内存中的分配空间。为了提高运算效率,有对空间进行了不同区域的划分,因为每一片区域都有特定的处理数据方式和内存管理方式。
栈内存:用于存储局部变量,当数据使用完,所占空间会自动释放。
堆内存:1、数组和对象,通过new建立的实例都存放在堆内存中。
2、每一个实体都有内存地址值。
3、实体中的变量都有默认初始化值。
4、实体不在被使用,会在不确定的时间内被垃圾回收器回收。
三、数组操作常见问题
1、数组脚标越界异常(ArrayIndexOutOfBoundsException)。例:
int[] arr = new int[2];
System.out.println(arr[3]);
访问到了数组中的不存在的脚标时发生。
2、空指针异常人生感悟(NullPointerException)。例:
int[]arr = null;
System.out.println(arr[0]);
arr引用没有指向实体,却在操作实体中的元素时。
四、数组中的数组
也称多维数组,这里我们主要讲二维数组。
格式1: int[][] arr= new int[3][2];
解释:以上格式表示定义了名称为arr的二维数组。有3个一维数组,每一个一维数组中有2个元素。一维数组的名称分别为arr[0],arr[1],arr[2]。给第一个一维数组1脚标位赋值为78写法是:arr[0][1] = 78。
格式2: int[][] arr= new int[3][];
注:此种格式中每个一维数组都是默认初始化值null。
格式3:int[][] arr = {{3,8,2},{2,7},{9,0,1,6}};//每一个一维数组中具体元素都初始化了。
注:一种特殊定义伤感的句子写法:int[]x,y[]; x是一维数组,y是二维数组。
二维数组在内存中的分配情况示例:
五、数组常见操作
1、 数组排序:
常见的排序方式:冒泡排序和选择排序。在Java已经定义好了一种排序方式,在开发使用中,直接调用即可。排序的方式有很多,其中最快的排序方式为希尔排序。
下面是我自己敲的选择和冒泡两种排序方式的程序:
选择排序程序:
- //使用选择排序方式对指定的数组进行排序
- class Demo
- {
- public static void main(String[] args)
- {
- int[] arr= {1,11,5,3,9,55,23,67,18};
- //输出原数组
- printArray(arr);
- //调用排序方法
- selectSort(arr);
- //输出排序后的数组
- printArray(arr);
- }
- /*
- 选择排序
- 1、先用0角标上的元素依次与其他元素进行比较,将较小值元素存放到0角标。
- 2、然后再拿1角标上的元素依次进行比较,以此类推。
- */
- public static void selectSort(int[] arr)
- {
- //外循环遍历数组
- for (int x=0;x<arr.length-1;x++)
- {
- //内循环比较大小
- for (int y=x+1;y<arr.length;y++)
- {
- //如果后一个元素比拿去比较的元素大,就交换两元素位置
- if(arr[x]>arr[y])
- {
- //arr[x]=arr[y];
- //arr[y]=temp;
- swap(arr,x,y);
- }
- }
- }
- }
- //遍历数组
- public static void printArray(int[] arr)
- {
- System.out.print("[");
- for (int x=0;x<arr.length;x++)
- {
- if(x!=arr.length-1)
- System.out.print(arr[x]+",");
- else
- System.out.print(arr[x]+"]");
- }
- //换行
- System.out.println();
- }
- //互换方法
- public static void swap(int[] arr,int a,int b)
- {
- arr[a]=arr[a]^arr[b];
- arr[b]=arr[a]^arr[b];
- arr[a]=arr[a]^arr[b];
- }
- }
输出结果:
冒泡排序程序:
- //使用冒泡排序方式对指定程序进行排序
- class Demo1
- {
- public static void main(String[] args)
- {
- int arr[]={22,63,89,13,6};
- //打印原数组
- printArray(arr);
- //调用排序方法
- bubbleSort(arr);
- //打印排序后的数组
- printArray(arr);
- }
- /*
- 冒泡排序
- 1、先从头角标相邻两个元素之间进行比较,将较大值存放在后一个元素中,然后再与后一个元素的进行比较,直至最大值存放到最后一个元素中。
- 2、再重复1操作,每次计较次数减一,一圈比完后存放的较大元素不再参与比较。
- */
- public static void bubbleSort(int[] arr)
- {
- for (int x=0;x<arr.length-1;x++)
- {
- for (int y=0;y<arr.length-1-x;y++)//-x:让没每一次比较的元素减少。-1:避免角标越界。
- {
- if(arr[y]>arr[y+1])
- swap(arr,y,y+1);
- }
- }
- }
- //遍历数组
- public static void printArray(int[] arr)
- {
- System.out.print("[");
- for (int x=0;x<arr.length;x++)
- {
- if(x!=arr.length-1)
- System.out.print(arr[x]+",");
- else
- System.out.print(arr[x]+"]");
- }
- //换行
- System.out.println();
- }
- //互换方法
- public static void swap(int[] arr,int a,int b)
- {
- arr[a]=arr[a]^arr[b];
- arr[b]=arr[a]^arr[b];
- arr[a]=arr[a]^arr[b];
- }
- }
输出结果
2、 折半查找
程序:
- /*
- 需求:将一个已知元素插入到一个有序数组中,要求不改变数组顺序,打印元素应该插入数组位置的角标。
- 思路:1、可以利用折半查找的方式,先定义两个变量,一个初始化0角标,作为最小值,一个初始化为最后一个角标,作为最大值,
- 再定义一个变量,存储最小值与最大值的一半,也就是中间位置,然后将已知元素与中间值位元素进行比较。
- 2、如果比中间值元素大,则将最小值变为中间值加1,继续取最小值与最大值的中间值元素与已经元素进行比较,以此反复
- 3、如果比中间值元素小,则将最大值变为中间值减1,继续取最小值与最大值的中间值元素与已经元素进行比较,以此反复
- */
- class HalfSearch
- {
- public static void main(String[] args)
- {
- int[] arr={2,6,9,11,15,19,22,30};
- //打印数组
- printArray(arr);
- int key=20;
- //用第一种折半方式输出插入的角标值
- System.out.println("当key=20在数组arr中插入的角标位置是:"+halfSearch1(arr,key));
- key=1;
- //用第二种折半方式输出插入的角标值
- System.out.println("当key=1在数组arr中插入的角标位置是:"+halfSearch2(arr,key));
- }
- //折半查找<一>
- public static int halfSearch1(int[] arr,int key)
- {
- int min=0,max=arr.length-1,mid=(max+min)/2;
- while(key!=arr[mid])
- {
- if(min>max)
- return min;
- else if(key>arr[mid])
- min=mid+1;
- else
- max=mid-1;
- mid=(max+min)>>>1;//折半操作
- }
- return mid;
- }
- //折半查找<二>
- public static int halfSearch2(int[] arr,int key)
- {
- int min=0,max=arr.length-1,mid;
- while(min<max)
- {
- mid=(max+min)>>>1;//折半操作
- if(key>arr[mid])
- min=mid+1;
- else if(key<arr[mid])
- max=mid-1;
- else
- return mid;
- }
- return min;
- }
- //遍历数组
- public static void printArray(int[] arr)
- {
- System.out.print("[");
- for (int x=0;x<arr.length;x++)
- {
- if(x!=arr.length-1)
- System.out.print(arr[x]+",");
- else
- System.out.print(arr[x]+"]");
- }
- //换行
- System.out.println();
- }
- }
运行结果:
3、 进制转换
十进制转换为二进制、八进制、十六进制的小程序:
- /*
- 使用查表法将十进制转换为二进制、八进制、十六进制
- */
- class Conversion
- {
- public static void main(String[] args)
- {
- int num=60;
- toBin(num);
- toOct(0);
- toHex(-num);
- }
- //转换为二进制
- public static void toBin(int num)
- {
- conversion(num,1,1);
- }
- //转换为八进制
- public static void toOct(int num)
- {
- conversion(num,7,3);
- }
- //转换为十六进制
- public static void toHex(int num)
- {
- conversion(num,15,4);
- }
- //转换
- public static void conversion(int num,int diwei,int yiwei)
- {
- //如果num等于0,结果输出为0
- if(num==0)
- {
- System.out.println("num="+0);
- return;
- }
- //定义一个包含二进制、八进制、十六进制的表
- char[] chs={'0','1','2','3','4','5','6','7',
- '8','9','A','B','C','D','E','F',};
- //定义一个临时容器
- char[] arr=new char[32];
- //定义一个操作数组的指针
- int pos=arr.length;
- //利用与低位最大值的方式取出低位,存到临时数组中
- while(num!=0)
- {
- arr[--pos]=chs[num&diwei];//--pos倒着往临时容器里存
- num >>>=yiwei; //无条件右移相应位数
- }
- //打印转换后的结果
- for(int x=pos;x<arr.length; x++)
- System.out.print(arr[x]);
- //换行
- System.out.println();
- }
- }
输出结果:
Java基础语法(三)---数组的更多相关文章
- Java基础语法(7)-数组
title: Java基础语法(7)-数组 blog: CSDN data: Java学习路线及视频 1.数组的概述 数组(Array),是多个相同类型数据按一定顺序排列的集合,并使用一个名字命名,并 ...
- Java基础语法(8)-数组中的常见排序算法
title: Java基础语法(8)-数组中的常见排序算法 blog: CSDN data: Java学习路线及视频 1.基本概念 排序: 是计算机程序设计中的一项重要操作,其功能是指一个数据元素集合 ...
- Java基础语法(数组)
第4天 Java基础语法 今日内容介绍 u 流程控制语句(switch) u 数组 第1章 流程控制语句 1.1 选择结构switch switch 条件语句也是一种很常用的选择语句,它和if条件语句 ...
- JavaSE入门学习9:Java基础语法之数组
一数组的定义 数组能够理解为是一个巨大的"盒子",里面能够按顺序存放多个类型同样的数据.比方能够定义int型的数组 scores存储4名学生的成绩. watermark/2/tex ...
- Java基础语法:数组
一.简介 描述: 数组是相同类型数据的有序集合. 其中,每一个数据称作一个数组元素,每个数组元素可以通过一个下标来访问它们. 基本特点: 数组的长度是确定的.数组一旦被创建,它的大小就是不可以改变的. ...
- Java基础语法<三> 输入输出
1. 读取输入 Scanner in = new Scanner(System.in); 输入一行(包含空格) String str = in.nextLine() 读取一个单词(以空白符作为 ...
- Java基础语法<六> 数组 Arrays
笔记整理 来源于<Java核心技术卷 I > <Java编程思想> 允许数组长度为0 new element[0] 数组长度为0与null不同 1. 数组拷贝 允许将一 ...
- Java基础语法(9)-面向对象之类的成员
title: Java基础语法(9)-面向对象之类的成员 blog: CSDN data: Java学习路线及视频 1.面向对象特征--封装 为什么需要封装?封装的作用和含义? 我要用洗衣机,只需要按 ...
- Java基础语法(10)-面向对象之三大特征
title: Java基础语法(9)-面向对象之类的成员 blog: CSDN data: Java学习路线及视频 1.面向对象特征--封装 为什么需要封装?封装的作用和含义? 我要用洗衣机,只需要按 ...
随机推荐
- ARKit 初体验
ARKIT是苹果公司在今年发布的一个AR开发包,用于现有的IOS设备,是的,就是用在手机或者平板上,类似于pokemon go的效果.看了下演示视屏,嗯,看起来很厉害. 对于一个资深软粉,居然被要求研 ...
- 【nodejs】nodejs 的linux安装(转)
(一) 编译好的文件 简单说就是解压后,在bin文件夹中已经存在node以及npm,如果你进入到对应文件的中执行命令行一点问题都没有,不过不是全局的,所以将这个设置为全局就好了. ./node -v ...
- .NET Core 成都线下面基会拉开序幕
2017年07月29日下午,由 .NET China Foundation 成都小组组织的 .NET Core 成都地区线下技术交流会在成都成华区某茶楼成功举行,这也是成都地区 .NET Core 非 ...
- 查看ubuntu的内核版本&获取roo…
1.查看内核版本命令 [root@AY130616190837708391Z ~]# cd .. (管理员权限) [root@AY130616190837708391Z /]# cd proc [ro ...
- 46. leetcode 500. Keyboard Row
500. Keyboard Row Given a List of words, return the words that can be typed using letters of alphabe ...
- 双向循环链表(C语言描述)(一)
双向循环链表是链表的一种,它的每个节点也包含数据域和指针域.为了方便程序维护,可以单独为数据域定义一种数据类型,这里以整型为例: typedef int LinkedListData; 双向循环链表( ...
- Wordpress解析系列之PHP编写hook钩子原理简单实例
Wordpress作为全球应用最广泛的个人博客建站工具,有很多的技术架构值得我们学习推敲.其中,最著名最经典的编码技术架构就是采用了hook的机制. hook翻译成中文是钩子的意思,单独看这个词我们难 ...
- Unity 继承MonoBehaviour脚本 执行顺序 详解
先看结果 Awake ->OnEnable-> Start ->-> FixedUpdate-> Update -> LateUpdate ->OnGUI ...
- NOIP 2002 提高组 字串变换
题目描述 已知有两个字串 A, B 及一组字串变换的规则(至多6个规则): A1 -> B1 A2 -> B2 规则的含义为:在 A$中的子串 A1 可以变换为 B1.A2 可以变换为 B ...
- 17个新手常见Python运行时错误
当初学 Python 时,想要弄懂 Python 的错误信息的含义可能有点复杂.这里列出了常见的的一些让你程序 crash 的运行时错误. 1)忘记在 if , elif , else , for , ...