------- android培训java培训、期待与您交流! ----------

数组:

数组的定义: 数组是相同类型数据的集合, 描述的是相同类型的若干个数据按照一定的先后顺序排列组合而成,其中每一个数据称作一个数组元素,每个数组元素可以通过一个下标来访问它们。

优点:可以自动给数组中的元素从0开始编号,方便操作这些元素。

数组的四个基本特点:

1.长度固定,一旦被创建它的长度就是不可改变的;

2.其元素类型必须是相同类型,不允许出现混合类型;

3.数组中的元素可以是任何数据类型,包括基本数据类型和引用数据类型;

4.数组发量属亍引用类型,数组也可以看做是对象,数组中的每个元素相当于该对象的成员发量,数组本身就是对象,Java中对象是在堆中的,因此数组无论保存原始类型还是其他对象类型,数组本身是在堆中的。

数组的拷贝:System.arrayCopy(源数组,从哪开始,目标数组,从哪开始贴,粘几个) 。

数组排序:Arrays.sort(被排序的数组) 。

二分法查找:Arrays.binarySearch(哪个数组,数组中的什么元素) 。

填充:Arrays.fill(a, 2, 4,100) 。//将数组a中2到4的索引的元素替换为100

格式1:

元素类型[] 数组名

= new 元素类型[元素个数或数组长度];

示例:int[] arr = new int[5];

格式2:

元素类型[] 数组名

= new 元素类型[]{元素,元素,……};

int[] arr = new int[]{3,5,1,7};

int[] arr = {3,5,1,7};

1.数组操作常见问题

数组脚标越界异常(ArrayIndexOutOfBoundsException)

int[] arr = new int[2];

System.out.println(arr[3]);

访问到了数组中的不存在的脚标时发生。

空指针异常(NullPointerException)

int[] arr = null;

System.out.println(arr[0]);

2.数组常见操作

获取最值(最大值,最小值)

排序(选择排序,冒泡排序)

折半查找(二分查找)

获取数组中的元素。通常会用到遍历。

/**
* 数组遍历问题,要求打印数组中的所有数
* 给定一个数组,输出最大最小值
*
*/
public class CharDemo
{
public static void main(String [] args)
{
int[] arr = {3,2,4,5,6,7,8};
printArrary(arr);
arraryMax(arr);
arraryMin(arr);
} //函数功能:遍历数组,并打印
public static void printArrary(int[] arr)
{
System.out.print("[ ");
for (int i=0;i<arr.length;i++)
{ if (i!=arr.length-1)
System.out.print(arr[i]+",");
else
System.out.println(arr[i]+" ]");
}
} //函数功能:打印数组最大值
//因为设定0角标元素为最值所以不用和自己比较,从1角标开始遍历比较就可以
public static void arraryMax(int[] arr)
{
int max = arr[0];
for (int i=1;i<arr.length;i++)
{
if (arr[i]>max)
max = arr[i];
}
System.out.println("[ "+max+" ]");
} //函数功能:打印数组最小值
public static void arraryMin(int[] arr)
{
int min = arr[0];
for (int i=1;i<arr.length;i++)
{
if (arr[i]<min)
min = arr[i];
}
System.out.println("[ "+min+" ]");
}
}
/**
* 排序的演示
* 选择排序
* 冒泡排序
*
*/
public class SortDemo
{
public static void main(String [] args)
{
int[] arr = {3,2,5,4,6,7,8,9,1};
selectSort(arr);
printArrary(arr);
bubbleSort(arr);
printArrary(arr);
} //数组内两个数换位
public static void swap(int[] arr,int x,int y)
{
int temp;
temp =arr[x];
arr[x] = arr[y];
arr[y] = temp;
} //按照格式遍历打印。
public static void printArrary(int[] arr)
{
System.out.print("[ ");
for (int t=0;t<arr.length;t++)
{
if (t!=arr.length-1)
System.out.print(arr[t]+",");
else
System.out.println(arr[t]+" ]");
}
} //给数组由小到大顺序排序,顺序排序
public static void selectSort(int[] arr)
{
for (int n=0;n<arr.length-1;n++)
{
for (int m=n+1;m<arr.length;m++)
{
if (arr[m]<arr[n])
swap(arr,n,m);
}
}
} //给数组由大到小排序,冒泡排序
public static void bubbleSort(int[] arr)
{
for (int i=0;i<arr.length-1;i++)
{
for(int c=0;c<arr.length-i-1;c++)
{
if (arr [c]<arr [c+1])
swap(arr,c,c+1);
}
}
}
}
/**
*
* 数组角标和查找等练习
*
*/
public class SearchDemo
{
public static void main(String[] args)
{
int[] arr = {1,2,3,4,6,7,8};
System.out.println(getArrary(arr,4));
System.out.println(getIndex(arr,5));
System.out.println(getArrary(arr,6));
} //定义一个函数,查找数组中某一数角标,返回数第一次出现的时候的角标
public static int getArrary(int[] arr,int key)
{
for (int i=0;i<arr.length;i++)
{
if (arr[i]==key)
return i;
}
return -1;
} //折半查找,只应用于有序数组
//java类库中定义了折半查找方法,开发时找API Arrarys.binarySearch(arr,4);
public static int halfSearch(int []arr,int key)
{
int min,mid,max;
min=0;
max=arr.length-1;
mid=(min+max)/2;
while (arr[mid]!=key)
{
if (key>arr[mid])
{
min=mid+1;
}
else if(key<arr[mid])
max=mid-1; mid=(min+max)/2;
}
return mid;
} //插入一个数到一个有序数组中,保持这个数组的有序
public static int getIndex(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;
}
}

二维数组

格式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][];

 二维数组中有3个一维数组

 每个一维数组都是默认初始化值null

 可以对这个三个一维数组分别进行初始化

arr[0] = new int[3];

arr[1] = new int[1];

arr[2] = new int[2];

------- android培训java培训、期待与您交流! ----------

黑马程序员——JAVA基础之数组的更多相关文章

  1. 黑马程序员----java基础笔记中(毕向东)

    <p>------<a href="http://www.itheima.com" target="blank">Java培训.Andr ...

  2. 黑马程序员Java基础班+就业班课程笔记全发布(持续更新)

    正在黑马学习,整理了一些课程知识点和比较重要的内容分享给大家,也是给自己拓宽一些视野,仅供大家交流学习,大家有什么更好的内容可以发给我 ,现有黑马教程2000G  QQ 1481135711 这是我总 ...

  3. 黑马程序员----java基础笔记上(毕向东)

    ------Java培训.Android培训.iOS培训..Net培训.期待与您交流! ------- 笔记一共记录了毕向东的java基础的25天课程,分上.中.下 本片为上篇,涵盖前10天课程 1. ...

  4. 黑马程序员——JAVA基础之语法、命名规则

    ------- android培训.java培训.期待与您交流! ---------- 1.java语言组成:关键字,标识符,注释,常量和变量,运算符,语句,函数,数组. 2.java关键字:被Jav ...

  5. 黑马程序员——JAVA基础之泛型和通配符

    ------- android培训.java培训.期待与您交流! ---------- 泛型:            JDK1.5版本以后出现新特性.用于解决安全问题,是一个类型安全机制. 泛型好处: ...

  6. 黑马程序员——JAVA基础之简述面向对象,类,变量,匿名对象

    ------- android培训.java培训.期待与您交流! ---------- 面向对象: 面向对象是相对面向过程而言 面向对象和面向过程都是一种思想 面向过程 强调的是功能行为 面向对象 将 ...

  7. 黑马程序员——JAVA基础之Collections和Arrays,数组集合的转换

    ------- android培训.java培训.期待与您交流! ---------- 集合框架的工具类:        Collections : 集合框架的工具类.里面定义的都是静态方法. Col ...

  8. 黑马程序员——JAVA基础之简述设计模式

    ------- android培训.java培训.期待与您交流! ---------- 设计模式(Design Patterns) 设计模式(Design pattern)是一套被反复使用.多数人知晓 ...

  9. 黑马程序员——JAVA基础之反射

      ------Java培训.Android培训.iOS培训..Net培训.期待与您交流! -------     Java 反射是Java语言的一个很重要的特征,它使得Java具体了"动态 ...

随机推荐

  1. [转]android Intent机制详解

    转自:http://blog.csdn.net/t12x3456/article/details/7688154 1.什么是Intent Intent是一种运行时绑定(run-time binding ...

  2. unix shell-01 file

    1 一个文件有三种访问方式: 1.读,可以显示该文件的内容 2.写,删除或者编辑这个文件 3.执行,如果该文件时一个shell脚本或程序 按照文件所针对的用户,用户可以分为三种: 1.文件属主,即该文 ...

  3. 2014年3月份第2周51Aspx源码发布详情

    MVC+EF某钢电子交易平台源码  2014-3-10 [VS2012]功能介绍:本源码是一套完整的电子交易平台系统,完全基于ASP.NET MVC+EF三层构架,开发环境为Visual Studio ...

  4. IOS导航栏的使用方法

    本文是使用纯代码实现一个导航栏的效果.单击按钮并且产生事件.基本思路是: 1.创建一个导航栏(UINavigationBar对象) 2.创建一个导航栏集合(UINavigationItem对象) 3. ...

  5. 转:HashMap深度解析(一)

      HashMap哈希码hashCodeequals 本文来自:高爽|Coder,原文地址:http://blog.csdn.net/ghsau/article/details/16843543,转载 ...

  6. GSM cell phone calls use outdated encryption that can now be cracked with rainbow tables on a PC

    Decrypting GSM phone calls Motivation. GSM telephony is the world’s most popular communication techn ...

  7. java.lang.IllegalStateException: Can not perform this action after onSaveInstanceState解决?

    做项目到最后整合的时候测试的时候发现  切换tab更换fragment的时候抛出了这个异常,根据异常信息Can not perform this action after onSaveInstance ...

  8. Functions

    Small The first rule of functions is that they should be small.The second rule of functions is that ...

  9. IOS 封装类的时候注释格式,使用的时候可以想官方库一样快捷显示

    /** @brief 详情 @param 参数 @note 注意 @return 返回值类型 @code 这里写例题代码 @endcode @see 相似的方法参考 */

  10. 安装webmin

    wget http://nchc.dl.sourceforge.net/project/webadmin/webmin/1.740/webmin-1.740.tar.gz 解压缩文件,命令是:tar ...