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已经定义好了一种排序方式,在开发使用中,直接调用即可。排序的方式有很多,其中最快的排序方式为希尔排序。

下面是我自己敲的选择和冒泡两种排序方式的程序:

选择排序程序:

[java] view plaincopy

  1. //使用选择排序方式对指定的数组进行排序
  2. class  Demo
  3. {
  4. public static void main(String[] args)
  5. {
  6. int[] arr= {1,11,5,3,9,55,23,67,18};
  7. //输出原数组
  8. printArray(arr);
  9. //调用排序方法
  10. selectSort(arr);
  11. //输出排序后的数组
  12. printArray(arr);
  13. }
  14. /*
  15. 选择排序
  16. 1、先用0角标上的元素依次与其他元素进行比较,将较小值元素存放到0角标。
  17. 2、然后再拿1角标上的元素依次进行比较,以此类推。
  18. */
  19. public static void selectSort(int[] arr)
  20. {
  21. //外循环遍历数组
  22. for (int x=0;x<arr.length-1;x++)
  23. {
  24. //内循环比较大小
  25. for (int y=x+1;y<arr.length;y++)
  26. {
  27. //如果后一个元素比拿去比较的元素大,就交换两元素位置
  28. if(arr[x]>arr[y])
  29. {
  30. //arr[x]=arr[y];
  31. //arr[y]=temp;
  32. swap(arr,x,y);
  33. }
  34. }
  35. }
  36. }
  37. //遍历数组
  38. public static void printArray(int[] arr)
  39. {
  40. System.out.print("[");
  41. for (int x=0;x<arr.length;x++)
  42. {
  43. if(x!=arr.length-1)
  44. System.out.print(arr[x]+",");
  45. else
  46. System.out.print(arr[x]+"]");
  47. }
  48. //换行
  49. System.out.println();
  50. }
  51. //互换方法
  52. public static void swap(int[] arr,int a,int b)
  53. {
  54. arr[a]=arr[a]^arr[b];
  55. arr[b]=arr[a]^arr[b];
  56. arr[a]=arr[a]^arr[b];
  57. }
  58. }

输出结果:

冒泡排序程序:

[java] view plaincopy

  1. //使用冒泡排序方式对指定程序进行排序
  2. class Demo1
  3. {
  4. public static void main(String[] args)
  5. {
  6. int arr[]={22,63,89,13,6};
  7. //打印原数组
  8. printArray(arr);
  9. //调用排序方法
  10. bubbleSort(arr);
  11. //打印排序后的数组
  12. printArray(arr);
  13. }
  14. /*
  15. 冒泡排序
  16. 1、先从头角标相邻两个元素之间进行比较,将较大值存放在后一个元素中,然后再与后一个元素的进行比较,直至最大值存放到最后一个元素中。
  17. 2、再重复1操作,每次计较次数减一,一圈比完后存放的较大元素不再参与比较。
  18. */
  19. public static void bubbleSort(int[] arr)
  20. {
  21. for (int x=0;x<arr.length-1;x++)
  22. {
  23. for (int y=0;y<arr.length-1-x;y++)//-x:让没每一次比较的元素减少。-1:避免角标越界。
  24. {
  25. if(arr[y]>arr[y+1])
  26. swap(arr,y,y+1);
  27. }
  28. }
  29. }
  30. //遍历数组
  31. public static void printArray(int[] arr)
  32. {
  33. System.out.print("[");
  34. for (int x=0;x<arr.length;x++)
  35. {
  36. if(x!=arr.length-1)
  37. System.out.print(arr[x]+",");
  38. else
  39. System.out.print(arr[x]+"]");
  40. }
  41. //换行
  42. System.out.println();
  43. }
  44. //互换方法
  45. public static void swap(int[] arr,int a,int b)
  46. {
  47. arr[a]=arr[a]^arr[b];
  48. arr[b]=arr[a]^arr[b];
  49. arr[a]=arr[a]^arr[b];
  50. }
  51. }

输出结果

2、 折半查找

程序:

[java] view plaincopy

  1. /*
  2. 需求:将一个已知元素插入到一个有序数组中,要求不改变数组顺序,打印元素应该插入数组位置的角标。
  3. 思路:1、可以利用折半查找的方式,先定义两个变量,一个初始化0角标,作为最小值,一个初始化为最后一个角标,作为最大值,
  4. 再定义一个变量,存储最小值与最大值的一半,也就是中间位置,然后将已知元素与中间值位元素进行比较。
  5. 2、如果比中间值元素大,则将最小值变为中间值加1,继续取最小值与最大值的中间值元素与已经元素进行比较,以此反复
  6. 3、如果比中间值元素小,则将最大值变为中间值减1,继续取最小值与最大值的中间值元素与已经元素进行比较,以此反复
  7. */
  8. class  HalfSearch
  9. {
  10. public static void main(String[] args)
  11. {
  12. int[] arr={2,6,9,11,15,19,22,30};
  13. //打印数组
  14. printArray(arr);
  15. int key=20;
  16. //用第一种折半方式输出插入的角标值
  17. System.out.println("当key=20在数组arr中插入的角标位置是:"+halfSearch1(arr,key));
  18. key=1;
  19. //用第二种折半方式输出插入的角标值
  20. System.out.println("当key=1在数组arr中插入的角标位置是:"+halfSearch2(arr,key));
  21. }
  22. //折半查找<一>
  23. public static int halfSearch1(int[] arr,int key)
  24. {
  25. int min=0,max=arr.length-1,mid=(max+min)/2;
  26. while(key!=arr[mid])
  27. {
  28. if(min>max)
  29. return min;
  30. else if(key>arr[mid])
  31. min=mid+1;
  32. else
  33. max=mid-1;
  34. mid=(max+min)>>>1;//折半操作
  35. }
  36. return mid;
  37. }
  38. //折半查找<二>
  39. public static int halfSearch2(int[] arr,int key)
  40. {
  41. int min=0,max=arr.length-1,mid;
  42. while(min<max)
  43. {
  44. mid=(max+min)>>>1;//折半操作
  45. if(key>arr[mid])
  46. min=mid+1;
  47. else if(key<arr[mid])
  48. max=mid-1;
  49. else
  50. return mid;
  51. }
  52. return min;
  53. }
  54. //遍历数组
  55. public static void printArray(int[] arr)
  56. {
  57. System.out.print("[");
  58. for (int x=0;x<arr.length;x++)
  59. {
  60. if(x!=arr.length-1)
  61. System.out.print(arr[x]+",");
  62. else
  63. System.out.print(arr[x]+"]");
  64. }
  65. //换行
  66. System.out.println();
  67. }
  68. }

运行结果:

3、 进制转换

十进制转换为二进制、八进制、十六进制的小程序:

[java] view plaincopy

  1. /*
  2. 使用查表法将十进制转换为二进制、八进制、十六进制
  3. */
  4. class  Conversion
  5. {
  6. public static void main(String[] args)
  7. {
  8. int num=60;
  9. toBin(num);
  10. toOct(0);
  11. toHex(-num);
  12. }
  13. //转换为二进制
  14. public static void toBin(int num)
  15. {
  16. conversion(num,1,1);
  17. }
  18. //转换为八进制
  19. public static void toOct(int num)
  20. {
  21. conversion(num,7,3);
  22. }
  23. //转换为十六进制
  24. public static void toHex(int num)
  25. {
  26. conversion(num,15,4);
  27. }
  28. //转换
  29. public static void conversion(int num,int diwei,int yiwei)
  30. {
  31. //如果num等于0,结果输出为0
  32. if(num==0)
  33. {
  34. System.out.println("num="+0);
  35. return;
  36. }
  37. //定义一个包含二进制、八进制、十六进制的表
  38. char[] chs={‘0‘,‘1‘,‘2‘,‘3‘,‘4‘,‘5‘,‘6‘,‘7‘,
  39. ‘8‘,‘9‘,‘A‘,‘B‘,‘C‘,‘D‘,‘E‘,‘F‘,};
  40. //定义一个临时容器
  41. char[] arr=new char[32];
  42. //定义一个操作数组的指针
  43. int pos=arr.length;
  44. //利用与低位最大值的方式取出低位,存到临时数组中
  45. while(num!=0)
  46. {
  47. arr[--pos]=chs[num&diwei];//--pos倒着往临时容器里存
  48. num >>>=yiwei; //无条件右移相应位数
  49. }
  50. //打印转换后的结果
  51. for(int x=pos;x<arr.length; x++)
  52. System.out.print(arr[x]);
  53. //换行
  54. System.out.println();
  55. }
  56. }

输出结果:

时间: 2024-08-05 14:54:34

Java基础语法(三)---数组的相关文章

黑马程序员——Java基础语法(三)---数组

------Java培训.Android培训.iOS培训..Net培训.期待与您交流! ------- 本篇博文主要的内容是java语法的第三部分--数组,数组同一种类型数据的集合.其实,数组就是一个容器.数组可以自动给数组中的元素从0开始编号,方便操作这些元素. 一.数组的定义 数组的格式一:元素类型[] 数组名 = new 元素类型[元素个数或数组长度];如:int[] arr=new int[5]; 数组定义的格式二:元素类型[]数组名=new元素类型[]{元素,元素,……

JavaSE入门学习9:Java基础语法之数组

一数组的定义 数组可以理解为是一个巨大的"盒子",里面可以按顺序存放多个类型相同的数据,比如可以定义int型的数组 scores存储4名学生的成绩. 数组中的元素都可以通过下标来访问,下标从0开始.例如,可以通过scores[0]获取数组中的第一个元素76, scores[2]就可以取到第三个元素92. 二操作数组只需要四个步骤: 1声明数组 语法:数据类型[ ] 数组名:或者 数据类型 数组名[ ]: 其中,数组名可以是任意合法的变量名,如: 2分配空间 简单地说,就是指定数组中最多

Java基础语法&lt;六&gt; 数组 Arrays

允许数组长度为0 new element[0] 数组长度为0与null不同 数组拷贝 允许将一个数组变量拷贝给另一个数组变量.这时,两个变量将引用同一个数组: int[] ele1 = ele2; ele1[5] = 12; //now ele2[5] is also 12 如果希望将一个数组的所有值拷贝到一个新的数组中去,就要使用Arrays类的copyTo方法: int[] copiedele = Arrays.copyOf(ele1,ele1.length); 第2个参数为数组的长度,通常

Java基础语法&lt;三&gt; 输入输出

1. 读取输入 Scanner in = new Scanner(System.in); 输入一行(包含空格) String str = in.nextLine() 读取一个单词(以空白符作为分隔符) String firstName = in.next(); 读取一个整数 int age = in.nextInt(); 读取一个浮点数 in.nextDouble() 输入是可见的,Scanner类不适合从控制台读取密码,Java 6引入Console实现 Console cons = Syst

JAVA学习(三):Java基础语法(变量、常量、数据类型、运算符与数据类型转换)

Java基础语法(变量.常量.数据类型.运算符与数据类型转换) 1.变量 Java中,用户可以通过指定数据类型和标识符来声明变量,其基本语法为: DataType identifier; 或 DataType identifier = value; 其中,DataType是变量类型,如int/string/char/double/boolean等:identifier是变量名称,即标识符:value就是声明变量的值. 注: a.标识符由数字0-9.大小写字母.下划线.美元符号.人民币符号以及所有

Java基础语法(一)---关键字、常量、变量、运算符

Java基础语法(一)---关键字.常量.变量.运算符一.关键字 定义:被Java赋予了特殊含义的单词. 特点:体现上都是英文小写. 1. 用于定义数据类型的关键字 基本数据类型: 整数类型: byte(1字节,最大值127) short(2字节,最大值为2^15-1) int(4字节,最大值为2^31-1) long(8字节,最大值为2^63-1) 浮点类型: float (单精度实数在内存中占32bit 有效数字为6~7位) double(双精度实数占内存单元为64bit 有效数字为15~1

第5天 Java基础语法

第5天 Java基础语法 今日内容介绍 方法 方法 方法概述 在我们的日常生活中,方法可以理解为要做某件事情,而采取的解决办法. 如:小明同学在路边准备坐车来学校学习.这就面临着一件事情(坐车到学校这件事情)需要解决,解决办法呢?可采用坐公交车或坐出租车的方式来学校,那么,这种解决某件事情的办法,我们就称为方法. 在java中,方法就是用来完成解决某件事情或实现某个功能的办法. 方法实现的过程中,会包含很多条语句用于完成某些有意义的功能--通常是处理文本,控制输入或计算数值. 我们可以通过在程序

第6天 Java基础语法

第6天 Java基础语法 今日内容介绍 自定义类 ArrayList集合 引用数据类型(类) 引用数据类型分类 提到引用数据类型(类),其实我们对它并不陌生,如使用过的Scanner类.Random类. 我们可以把类的类型为两种: 第一种,Java为我们提供好的类,如Scanner类,Random类等,这些已存在的类中包含了很多的方法与属性,可供我们使用. 第二种,我们自己创建的类,按照类的定义标准,可以在类中包含多个方法与属性,来供我们使用. 这里我们主要介绍第二种情况的简单使用. 自定义数据

Java基础语法(二)

目录 Java基础语法(二) 一.强类型语言 二.数据类型分类 1.基本数据类型 2.引用数据类型 三.基本类型转换 自动类型转换 强制类型转换 四.表达式类型的自动提升 Java基础语法(二) 承接上篇,谈到不同变量装载着不同数据类型的数据,那么Java支持的数据类型有哪些呢,本篇做一点小小的探究. 一.强类型语言 Java就是一种强类型的语言,包含着以下含义: 所有的变量必须在声明之后才能使用,不能用的不明不白或者用得很随意. 指定类型的变量只能结束类型与之匹配的值,很好理解,种瓜得瓜,种豆