1 数组也是一种类型

  • Java中要求所有的数组元素具有相同的数据类型。因此在一个数组中,数组元素的类型是唯一的,不能存储多种类型的数据。
  • 一旦数组的初始化完成,数组在内存中所占的空间将被固定下来,因此数组的长度不可以被改变。即使某个数组元素的数据被清空,他占的空间依然被保留,依然属于该数组,数组的长度依然不变。
  • Java的数组既可以存储基本类型的数据,也可以存储引用类型的数据,只要所有的数组元素具备相同的类型即可。
  • 值得指出的是,数组也是一种数据类型,是引用类型。所以可以把数组作为数组的元素,也就构成了二维数组

2 定义一个数组

  数组的定义可以采用两种方法,推荐采用第一种,这样变量的类型是数组这一概念更加直接。

  1. (1) type[] arrayName;
  2. (2) type arrayName[];

  数组是一个引用类型的变量,因此使用它定义一个变量时,仅仅表示定义了一个引用变量(也就是定义了一个指针),这个引用变量还未指向任何有效的内存,因此定义数组时并没有指定数组的长度,这个应用变量并没有指向任何有效的内存空间,所以还不能被使用,需要对其初始化。

3 初始化数组

  注意,不要在进行初始化时,既指定数组的长度也为每个数组元素分配初始值。 一般采用下列方法中的一种。

3.1 静态初始化

  初始化时由程序员显示指定每个数组元素的初始值,由系统决定数组长度。

  1. arrayName = new type[] {element1 , element2 , element3 , element4...};
  • 此处的type必须与定义数组变量时所用的type相同,也可以是定义时的type的子类
  • 执行静态初始化时,显示指定的数组元素值的类型必须与new关键字后面的type类型相同,或者时其子类的实例。

3.2 动态初始化

  初始化时程序员只指定数组长度,由系统为数组元素分配初始值。

  1. arrayName = new type[length];

3.3 更简洁的方法

  如果我们在定义的时候就对数组进行静态初始化,可以用一种更简洁的方法。

  1. type[] arrayName = {element1 , element2 , ...};

4 遍历数组

  Java为数组提供了一个更简单的循环,foreach循环。这种循环会自动遍历数组和集合,更加简洁。使用foreach时无需获得数组和集合的长度,无需根据指引访问数组元素和集合元素。语法:

  1. for(type variableName : array |collection){
  2. //variableName 自动迭代访问每个元素
  3. } 

  variableName 是一个形参名,foreach 会自动将数组元素依次赋给该变量。冒号后面写数组名或集合名

  foreach 方法不能修改原数组的值,只能读取,因为我们在语句里面直接访问的是形参,而不是数组本身,foreach 会自动将数组的值赋给形参供我们提取。

5 深入数组(内存)

  在这里我们假设定义的是 int[] 类型。

  • 在我们定义一个数组变量的时候,系统会在栈内存存放一个变量,这个变量的类型是引用类型,这个变量的值为 null ,并不指向任何有效的内存空间。
  • 接着我们用 new 关键字为其创建了一个 int[] 类型的对象,这个对象存放在系统的堆内存中,在用“=”将其赋给变量的时候,实际上是将堆内存里对象的地址赋给了变量,这时候就可以通过”arrayName[index]“的方式访问数组的值。这里假设数组长度是5。

  • 假设我们再创建一个数组变量 array2,并将 arrayName 赋给它,这时候 array2 接受到的实际是 arrayName 变量存储的地址,所以这两个变量将指向同一个数组。若我们把 1 赋给array2[0],这时候我们打印 arrayName[0] 的时候会发现,它的值也是1,这是因为它们指向的是同一个内存中存储的值。

6 数组常用方法

6.1 插入算法

  一个数组有序,添加一个元素后,数组依然有序。

  1. public class AddNumToArray{
  2. public static void main(String[] args){
  3. // 一个有序的数组,向该数组中添加一个元素,数组依然有序。
  4. int[] arr = {1,3,7,9,12,20,0};
  5. int t = 0;
  6. // 【1】找位置
  7. int loc = -1; // 表示t应该添加到的位置
  8. for(int i = 0;i<arr.length-1;i++){
  9. if(arr[i] >= t){
  10. loc = i;
  11. break;
  12. }
  13. }
  14. System.out.println("loc = "+loc);
  15. if(loc < 0){ // 没找到合适的位置
  16. arr[arr.length-1] = t;
  17. }else{
  18. // 【2】依次后移
  19. for(int j=arr.length-1;j>loc;j--){
  20. arr[j] = arr[j-1];
  21. }
  22. // 【3】添加插入的值
  23. arr[loc] = t;
  24. }
  25. // 验证
  26. for(int i = 0;i<arr.length;i++){
  27. System.out.print(arr[i]+"\t");
  28. }
  29. }
  30. }

  

6.2 删除算法

  从数组中删除一个数据,继续保持有序排列

  1. public class DeleteNumFromArray{
  2. public static void main(String[] args){
  3. // 删除算法
  4. int[] arr = {1,3,7,9,12,20};
  5. int t = 1;
  6. // 【1】找位置
  7. int loc = -1;
  8. for(int i=0;i<arr.length;i++){
  9. if(t == arr[i]){
  10. loc = i;
  11. break;
  12. }
  13. }
  14. // 【2】移动元素
  15. if(loc < 0){
  16. System.out.println(t+"在数组中不存在");
  17. }else{
  18. for(int j = loc;j<arr.length-1;j++){
  19. arr[j] = arr[j+1];
  20. }
  21. // 【3】最后一个元素置0
  22. arr[arr.length-1] = 0;
  23. }
  24. // 验证
  25. for(int i = 0;i<arr.length;i++){
  26. System.out.print(arr[i]+"\t");
  27. }
  28. }
  29. }

  

6.3 冒泡排序法

  将无序数组按顺序排列

  1. public class Test10{
  2. public static void main(String[] args){
  3. // 对一个无序的数组进行排序
  4. int[] arr = {10,5,3,4,2,9,7};
  5. int tmp = 0;
  6. for(int i=0;i<arr.length-1;i++){ // 外层控制趟数
  7. for(int j=0;j<arr.length-1-i;j++){ // 两两比较
  8. if(arr[j]>arr[j+1]){
  9. tmp = arr[j];
  10. arr[j] = arr[j+1];
  11. arr[j+1] = tmp;
  12. }
  13. }
  14. }
  15. for(int i=0;i<arr.length;i++){
  16. System.out.print(arr[i]+"\t");
  17. }
  18. }
  19. }

  

Java 数组及数组常用算法的更多相关文章

  1. 【Java】-NO.13.Algorithm.1.Java Algorithm.1.001-【Java 常用算法手册 】-

    1.0.0 Summary Tittle:[Java]-NO.13.Algorithm.1.Java Algorithm.1.001-[Java 常用算法手册 ]- Style:Java Series ...

  2. Java基础5一数组的常见应用算法

    常用算法 1.冒泡排序: 原理:比较两个相邻的元素,将值大的元素交换至右端 示例: public static void bubbleSort(int[] a) { int n = a.length; ...

  3. java基础之数组常用操作

    常用的对数组进行的操作 1.求数组中最大值,最小值 思路:假设下标为0的元素是最大值,遍历数组,依次跟max进行比较,如果有元素比这个max还大,则把这个值赋给max.最小值同样 public cla ...

  4. javascript中数组的常用算法深入分析

    Array数组是Javascript构成的一个重要的部分,它可以用来存储字符串.对象.函数.Number,它是非常强大的.因此深入了解Array是前端必修的功课.本文将给大家详细介绍了javascri ...

  5. 「面试指南」JS数组Array常用算法,Array算法的一般解答思路

    先看一道面试题 在 LeetCode 中有这么一道简单的数组算法题: // 给定一个整数数组 nums 和一个目标值 target, // 请你在该数组中找出和为目标值的那两个整数,并返回他们的数组下 ...

  6. 数据结构与算法系列2 线性表 使用java实现动态数组+ArrayList源码详解

    数据结构与算法系列2 线性表 使用java实现动态数组+ArrayList源码详解 对数组有不了解的可以先看看我的另一篇文章,那篇文章对数组有很多详细的解析,而本篇文章则着重讲动态数组,另一篇文章链接 ...

  7. 大数据学习day15----第三阶段----scala03--------1.函数(“_”的使用, 函数和方法的区别)2. 数组和集合常用的方法(迭代器,并行集合) 3. 深度理解函数 4 练习(用java实现类似Scala函数式编程的功能(不能使用Lambda表达式))

    1. 函数 函数就是一个非常灵活的运算逻辑,可以灵活的将函数传入方法中,前提是方法中接收的是类型一致的函数类型 函数式编程的好处:想要做什么就调用相应的方法(fliter.map.groupBy.so ...

  8. 【转】java中byte数组与int类型的转换(两种方式)----不错

    原文网址:http://blog.csdn.net/piaojun_pj/article/details/5903009 java中byte数组与int类型的转换,在网络编程中这个算法是最基本的算法, ...

  9. 第81节:Java中的数组

    第81节:Java中的数组 本节介绍数组的基本概念,数据就是一种数据结构,可以用来存储多个数据,每个数组中可以存放相同类型的数据.比如,在学校,我们是一个班,这里的班级中每个同学都是这个班级数组中的元 ...

随机推荐

  1. TensorFlow实现分布式计算

    摘要: 1.代码例子 内容: 1.代码例子 <TensorFlow实战>实现CNN处理CIFAR10数据,并模拟单机多个CPU同步数据并行计算 <TensorFlow实战>实现 ...

  2. OKHttp源码学习--HttpURLConnection HttpClient OKHttp Get and post Demo用法对比

    1.HttpURLConnection public class HttpURLConnectionGetAndPost { private String urlAddress = "xxx ...

  3. Java代码规范与质量检测插件SonarLint

    1.  SonarLint SonarLint是一个代码质量检测插件,可以帮助我们检测出代码中的坏味道 下载与安装 在需要检测的单个文件或者单个项目上右键 --> Analyze --> ...

  4. asp.net core系列 42 Web 应用 分部视图

    一.分部视图 对于MVC 视图和 Razor Pages 页面,都有分部视图功能.通常将 MVC 视图和 Razor Pages 页面统称为“标记文件”,下面会常提到该名词.使用分部视图的优势包括:( ...

  5. 前端笔记之ES678&Webpack&Babel(中)对象|字符串|数组的扩展&函数新特性&类

    一.对象的扩展 1.1对象属性名表达式 ES6可以在JSON中使用[]包裹一个key的名字.此时这个key将用表达式作为属性名(被当做变量求值),这个key值必须是字符串. var a = 'name ...

  6. [翻译 EF Core in Action 2.0] 查询数据库

    Entity Framework Core in Action Entityframework Core in action是 Jon P smith 所著的关于Entityframework Cor ...

  7. Python:游戏:五子棋之人机对战

    本文代码基于 python3.6 和 pygame1.9.4. 五子棋比起我之前写的几款游戏来说,难度提高了不少.如果是人与人对战,那么,电脑只需要判断是否赢了就可以.如果是人机对战,那你还得让电脑知 ...

  8. Android studio无法创建类和接口问题解决办法。提示 Unable to parse template "Class"

    重新配置了studio 的工作环境, 没问题,后来加需求要新增java类和接口,这就出现问题了,新建的时候,就会报错: Unable to parse template "Interface ...

  9. SVN使用规范

    1.提交之前先更新.当完成功能之后,首先检查自己修改了什么 ,然后通过编译并且自己测试之后,谨慎地提交,不可强行提交. 2.在更新时注意所更新文件的列表,如果提交过程中产生了更新,也需要重新编译并且完 ...

  10. Sqlserver 事务处理模板

    USE StuDB GO /****** Object: StoredProcedure [dbo].[proc_live_send_answer_v4] Script Date: 06/20/201 ...