数组对于每一门编程语言来说都是重要的数据结构之一,当然不同语言对于数组的实现及处理也不尽相同。
  Java语言中提供的数组是用来存储固定大小的同类型元素。如:声明一个数组变量,numbers[100]来代替直接声明100个独立变量number0,number1,...,number99。本文将介绍Java中对于数组的一些简单操作及应用。
  1、数组的扩容

 /**
* 数组的扩容:本质上是先定义一个更大的数组,然后将原数组里面的元素原封不动的拷贝到新数组中
* @param arr:要扩容的数组
* @return:返回扩容后的新数组
*/
public static String[] extendRange(String[] arr) {
//使原数组扩容为原来的2倍
String[] strArr = new String[arr.length*2];
System.arraycopy(arr, 0, strArr, 0, arr.length);
return strArr;
}

  2、数组的查找

 /**
* 数组的查找:在给定的数组中查找出指定的元素
* @param arr:要查找的数组
* @param index:要查找的元素
* @return:若找到,则返回数组中元素所在的索引,若没有找到则返回-1
*/
public static int searchElement(String[] arr,String str) {
//遍历数组,将数组中的元素与要查找的元素进行一一比对
for(int i=0;i<arr.length;i++) {
if(arr[i]==str) {
return i;
}
}
return -1;
}

  3、元素的插入

 /**
* 元素的插入:在给定的数组中的特定位置插入指定的元素
* 注意:在测试此方法前,应先保证数组索引不会出现越界异常,可先调用extendRange(String[] arr)进行数组扩容
* @param arr:给定的数组
* @param index:要插入的元素索引
* @param str:要插入的元素
* @return:返回插入后的数组
*/
public static String[] insertElement(String[] arr,int index,String str) {
//先找到数组中索引为index的位置
int equalsIndex = -1; //记录数组中索引为index的位置
for(int i=0;i<arr.length;i++) {
if(i==index) {
equalsIndex = i;
break;
}
}
//找到了
if(equalsIndex!=-1) {
//将index索引所在元素及之后的所有元素往后移动一个位置,再在index索引所在位置插入指定元素
for(int i=arr.length-2;i>=equalsIndex;i--) {
arr[i+1]=arr[i];
}
arr[equalsIndex]=str;
}else {
//没有找到
System.out.println("对不起,您输入的数组索引不存在!");
}
return arr;
}

  4、元素的修改

 /**
* 元素的修改:将数组中指定的元素修改为给定的元素
* @param arr:给定的数组
* @param strOld:要修改的元素
* @param strNew:修改后的元素
* @return:返回修改后的数组
*/
public static String[] modifyElement(String[] arr,String strOld,String strNew) {
//调用searchElement(String[] arr,String str)方法查找出要修改的元素所在的索引
int index = searchElement(arr,strOld);
//找到啦
if(index!=-1) {
arr[index] = strNew;
}else {
//没找到
System.out.println("对不起,您要修改的元素不存在!");
}
return arr;
}

  5、元素的删除

 /**
* 元素的删除:将数组中指定的元素删除
* @param arr:给定的数组
* @param str:要删除的元素
* @return:返回删除后的数组
*/
public static String[] deleteElement(String[] arr,String str) {
//调用searchElement(String[] arr,String str)方法查找出要修改的元素所在的索引
int index = searchElement(arr, str);
//找到啦
if(index!=-1) {
//将index所在及以后索引的元素依次前移一位
for(int i=index;i<arr.length-1;i++) {
arr[i]=arr[i+1];
}
//将最后一位置为空
arr[arr.length-1]=null;
}else {
//没找到
System.out.println("对不起,您删除的元素不存在!");
}
return arr;
}

Java中对数组的操作的更多相关文章

  1. JAVA中,数组的操作与排序

    自己写了正向反向的冒泡排序,还用了静态和NEW方法实现. import java.util.Arrays; public class HelloJava { public static void ma ...

  2. Java中JNI的使用详解第五篇:C/C++中操作Java中的数组

    在Java中数组分为两种: 1.基本类型数组 2.对象类型(Object[])的数组(数组中存放的是指向Java对象中的引用) 一个能通用于两种不同类型数组的函数: GetArrayLength(ja ...

  3. 【JAVA零基础入门系列】Day10 Java中的数组

    什么是数组?顾名思义,就是数据的组合,把一些相同类型的数放到一组里去. 那为什么要用数组呢?比如需要统计全班同学的成绩的时候,如果给班上50个同学的成绩信息都命名一个变量进行存储,显然不方便,而且在做 ...

  4. 第81节:Java中的数组

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

  5. JAVA中的集合容器操作类

    目录 JAVA中的集合容器操作类 List集合 ArrayList的操作方法说明 LinkedList Stack Set Map Queue 总结 JAVA中的集合容器操作类 Java容器类库总共分 ...

  6. Java中的数组与集合

    此文转载自:http://student-lp.iteye.com/blog/2082362 在java编程的过程中,我们不能确定某一类型的对象到底会需要多少,为了解决这个问题,java提供了容纳对象 ...

  7. Java中的数组和方法

    3.1 数组的定义和使用 数组(Array)是用来存储一组相同数据类型数据的集合.数组中的每个数据称为一个元素(element),数组可以分为一维数组,二维数组和多维数组.我们 主要讲解一维数组和二维 ...

  8. JavaScript jQuery 中定义数组与操作及jquery数组操作

    首先给大家介绍javascript jquery中定义数组与操作的相关知识,具体内容如下所示: 1.认识数组 数组就是某类数据的集合,数据类型可以是整型.字符串.甚至是对象Javascript不支持多 ...

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

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

随机推荐

  1. css固定表头,表单内容可以滑动

    <html><head>    <meta charset="utf-8">    <title>Table</title&g ...

  2. SpringBoot全局日志管理(AOP)

    1.在pom.xml中引入aop的jar包 <dependency> <groupId>org.springframework.boot</groupId> < ...

  3. 爬虫框架之Scrapy

    一.介绍 二.安装 三.命令行工具 四.项目结构以及爬虫应用简介 五.Spiders 六.Selectors 七.Items 八.Item Pipelin 九. Dowloader Middeware ...

  4. 1005:Number Sequence(hdu,数学规律题)

    Problem Description A number sequence is defined as follows: f(1) = 1, f(2) = 1, f(n) = (A * f(n - 1 ...

  5. 《剑指offer》 包含min函数的栈

    本题来自<剑指offer> 包含min函数的栈 题目: 定义栈的数据结构,请在该类型中实现一个能够得到栈中所含最小元素的min函数(时间复杂度应为O(1)). 思路: 举例子让抽象问题具体 ...

  6. jsp 错误处理

    JSP提供了很好的错误处理能力.除了在Java代码 中可以使用try语句,还可以指定一个特殊页面.当应 用页面遇到未捕获的异常时,用户将看到一个精心设计 的网页解释发生了什么,而不是一个用户无法理解的 ...

  7. 拓扑排序基础 hdu1258,hdu2647

    由这两题可知拓扑排序是通过“小于”关系加边建图的 hdu2647 /* 拓扑排序的原则是把“小于”看成有向边 此题反向建图即可 并且开num数组来记录每个点的应该得到的权值 */ #include&l ...

  8. 安装mysql后在/var/log/mysqld.log 中找不到临时密码

    centos7通过yum装完mysql,使用grep 'temporary password' /var/log/mysqld.log找不到root密码打开mysqld.log中根本没有tempora ...

  9. 在一些开源框架中,dist文件夹是什么意思

    全称是distribution. distribution英 [dɪstrɪ'bjuːʃ(ə)n]美 ['dɪstrə'bjʊʃən]: 发行版 n. 分布:分配 在某些框架中,因为开发和发布是的内容 ...

  10. Appium Python API 中文版

    Appium_Python_Api文档 1.contextscontexts(self): Returns the contexts within the current session. 返回当前会 ...