zoukankan      html  css  js  c++  java
  • Arrays

    A(重点掌握)

    B(掌握)

    C(了解)

    1.命令行参数(C)

    定义:

    在程序运行过程中,可以向应用程序传一些参数,这些参数就叫命令行参数。

    1 public class Test01{
    2     public static void main(String[] args){
    3         System.out.println(args.length);
    4         
    5         for(int i= 0;i<args.length;i++){
    6             System.out.println(args[i]);
    7         }
    8     }
    9 }

    命令行参数以字符串的形式传入args数组中。可以一次传递0-多个参数,以空格分割。

    如果参数中本身包含空格,需要使用引号引起来。

    2.Arrays(A)

    jdk中为了便于开发,给开发者提供了Arrays类,其中包含了很多数组的常用操作。例如快速输出、排序、查找等。

    我们可以在JDK文档(JDK_API_1_6_zh_CN)上查看Arrays类在文档的位置:所有类java.uti下的类arrays。

    (1)常用方法

     1 import java.util.Arrays;
     2 public class Test02{
     3     public static void main(String[] args){
     4         
     5         int[] arr = {4,2,3,1};
     6         // 【1】数组的字符串形式
     7         String str = Arrays.toString(arr);
     8         System.out.println(str);
     9         
    10         // 【2】sort对数组排序(只能升序)-> 内部使用快速排序。
    11         Arrays.sort(arr);
    12         System.out.println(Arrays.toString(arr));
    13         
    14         // 【3】fill 填充数组
    15         //Arrays.fill(arr,0);
    16         //System.out.println(Arrays.toString(arr));
    17         
    18         // 【4】equals(arr1,arr2) 判断两个数组是否相等。
    19         // 数组相等的条件:a.长度相等 b.对应位置元素相等。
    20         int[] arr2 = {1,2,3};
    21         System.out.println(Arrays.equals(arr,arr2));
    22     }
    23 }

    (2)二分查找法

    二分法查找必须是有序的数组,如果找到返回索引如果没有找到,返回-插入点-1插入点就是key应该放到数组的位置。

    下面的代码为二分查找法的原理(理解即可)

     1 private static int binarySearch0(long[] a, int fromIndex, int toIndex,
     2                                      long key) {
     3         int low = fromIndex;
     4         int high = toIndex - 1;
     5 
     6         while (low <= high) {
     7             int mid = (low + high) >>> 1;
     8             long midVal = a[mid];
     9 
    10             if (midVal < key)
    11                 low = mid + 1;
    12             else if (midVal > key)
    13                 high = mid - 1;
    14         else
    15                 return mid; // key found
    16         }
    17         return -(low + 1);  // key not found.
    18     }

    (3)数组的复制

    copyOf(arr,len) arr复制len个长度的元素并返回新数组。如果len>arr.length,数组的长度末尾用0填充

    copyOfRange(arr,from,to) arrfrom(包含)位置开始复制到to(不包含)这个范围的元素到新数组中。含头不含尾。

     

     1 import java.util.Arrays;
     2 public class Test04{
     3     public static void main(String[] args){
     4         
     5         int[] arr = {1,3,4,6,8};
     6         
     7         int[] newArr = Arrays.copyOf(arr,6);
     8         System.out.println(Arrays.toString(newArr));
     9         
    10         // copyOfRange(arr,from,to)
    11         int[] newArr2 = Arrays.copyOfRange(arr,1,3);
    12         System.out.println(Arrays.toString(newArr2));
    13     }
    14 }

     

    其中System也提供了赋值数组的方法。

    arraycopy(srcArr,srcPos,destArr,destPos,len)

    srcArr:要复制的源数组

    srcPos:srcArrsrcPos位置开始复制

    destArr:复制到的目标数组

    destPos:目标数组destPos开始存放

    len:源数组中复制len个长度

     

    1 int[] arr2 = new int[arr.length];
    2 System.arraycopy(arr,1,arr2,0,3);
    3 System.out.println(Arrays.toString(arr2));

     

    二维数组(B)

    定义:

    就是数组的元素也是一个数组

    二维数组表示行列二维结构

     (1)二维数组的声明

    根据二维数组的定义

     1 import java.util.Arrays;
     2 public class Test05{
     3     public static void main(String[] args){
     4         
     5         // 二维数组
     6         //int[]
     7         // (int[]) []
     8         
     9         
    10         // 【1】声明
    11         int[][] arr;
    12         // 【2】初始化一个能存3个一维数组的二维数组
    13         arr = new int[3][];
    14         
    15         // 【3】赋值
    16         int[] arr1 = {1,3,4,5};
    17         int[] arr2 = {1,3,4};
    18         int[] arr3 = {2,1,6,4};
    19         
    20         arr[0] = arr1;
    21         arr[1] = arr2;
    22         arr[2] = arr3;
    23         
    24         System.out.println(arr);
    25         System.out.println(Arrays.toString(arr));
    26     }
    27 }

    此时arr = new int[3][];只分配了二维数组的空间,一维数组没有分配空间。

    声明一个规则的二维数组

     1 import java.util.Arrays;
     2 public class Test06{
     3     public static void main(String[] args){
     4         
     5         // 声明一个规则的二维数组,3行4列
     6         int[][] arr;
     7         arr = new int[3][4];
     8         
     9         arr[0][0] = 10;
    10         arr[0][1] = 20;
    11         arr[0][2] = 30;
    12         arr[0][3] = 40;
    13         
    14         arr[1][0] = 100;
    15         arr[1][1] = 200;
    16         arr[1][2] = 300;
    17         arr[1][3] = 400;
    18         
    19         arr[2][0] = 1000;
    20         arr[2][1] = 2000;
    21         arr[2][2] = 3000;
    22         arr[2][3] = 4000;
    23         
    24         System.out.println(Arrays.toString(arr));
    25     }
    26 }

    此时,二维数组已经分配好空间,同时一维分配好空间。

    已知二维数组的值数,可以考虑字面量声明

     1 import java.util.Arrays;
     2 public class Test07{
     3     public static void main(String[] args){
     4         
     5         // 声明字面量二维数组
     6         int[][] arr = {
     7             {10,20,30,40},
     8             {100,200,300},
     9             {1000,2000,3000,4000}
    10         };
    11         System.out.println(Arrays.toString(arr));
    12     }
    13 }

    (2)二维数组的遍历

     1 import java.util.Arrays;
     2 public class Test08{
     3     public static void main(String[] args){
     4         
     5         // 声明字面量二维数组
     6         int[][] arr = {
     7             {10,20,30,40},
     8             {100,200,300},
     9             {1000,2000,3000,4000}
    10         };
    11         // System.out.println(Arrays.toString(arr));
    12         
    13         /*
    14         for(int i=0;i<arr.length;i++){
    15             int[] t = arr[i];
    16             for(int j=0;j<t.length;j++){
    17                 System.out.print(t[j]+"	");
    18             }
    19             System.out.println();
    20         }
    21         */
    22         
    23         
    24         for(int i=0;i<arr.length;i++){
    25             for(int j=0;j<arr[i].length;j++){
    26                 System.out.print(arr[i][j]+"	");
    27             }
    28             System.out.println();
    29         }
    30     }
    31 }

    总结

    二维数组是行列结构,使用双层for循环,外层for用于控制行,内层for用于控制列

    行列结构 => 双层for遍历。

     

    基本数据类型和引用数据类型赋值的区别

     1 import java.util.Arrays;
     2 public class Test09{
     3     public static void main(String[] args){
     4         
     5         // 基本数据类型的赋值
     6         int a = 10;
     7         int b;
     8         b = a;
     9         // a? b?
    10         b = 20;
    11         // a? b?
    12         
    13         // 引用数据类型的赋值
    14         int[] arr = {1,3,5};
    15         int[] arr2 = arr;
    16         arr2[0] = 100;
    17         
    18         System.out.println("arr:"+arr);
    19         System.out.println("arr2:"+arr2);
    20         
    21         System.out.println("arr[0]:"+arr[0]);
    22         
    23     }
    24 }

    基本类型与引用类型赋值时的差别

    基本数据类型赋值时,复制的是值

    引用数据类型赋值时,复制的是引用

     

     

  • 相关阅读:
    ASP.NET WEB API 自定义模型校验过滤器
    使用asp.net mvc部分视图渲染html
    .Net中的并行编程-7.基于BlockingCollection实现高性能异步队列
    python爬虫技术的选择
    优雅的处理异常
    解决asp.net动态压缩
    .Net中的并行编程-6.常用优化策略
    使用快捷键提升C#开发效率
    .Net中的并行编程-5.流水线模型实战
    .Net中的并行编程-4.实现高性能异步队列
  • 原文地址:https://www.cnblogs.com/xfbb/p/10731787.html
Copyright © 2011-2022 走看看