import java.util.Arrays;

 public class ArrayOperator {

     public static void main(String[] args) {
// TODO Auto-generated method stub
ArrList list = new ArrList();
list.add(5);
list.add(7);
list.add(6);
System.out.println(list.sizeof());
// list.remove(0);
list.insert(1, 7);
System.out.println(list.toString());
System.out.println(list.search(6)); } }
class ArrList{
//定义元素个数
private int size = 0;
//初始定义数组
private int[] data = new int[10];
public ArrList(){
}
public ArrList(int inificapacity){ //初始化数组容量的构造方法
if(inificapacity < 0){
throw new ArrayIndexOutOfBoundsException();
}else {
data = new int[inificapacity];
}
}
public boolean isEmpty(){ //判断数组是否为空操作
return size ==0;
}
public void grow(){ //判断元素是否需要扩容
if(data.length <=1){
data = Arrays.copyOf(data, data.length+1);
}else{
data = Arrays.copyOf(data, data.length+data.length>>1);
} }
public void add(int element){ //增加元素操作
if(size >= data.length){
this.grow();
}else{
data[size++] = element;
}
}
public void insert(int index,int element){ //插入元素操作
if(index < 0){
throw new ArrayIndexOutOfBoundsException();
}else if(index <= size){
for(int i = size-1; i >= index;i--){
data[i+1] = data[i];
} data[index] = element;
size++; }else{
throw new ArrayIndexOutOfBoundsException();
}
}
public void remove(int index){
if(index < 0){
throw new ArrayIndexOutOfBoundsException();
}
else if(index < size){
for(int i = index; i < data.length-1;i++){
data[i] = data[i+1];
}size--;
}else{
throw new ArrayIndexOutOfBoundsException();
}
}
public int search(int element){ for(int i = 0; i < size;i++){
if(data[i] == element){ return i;
}
}
return -1;
}
public int ele(int index){
if(index < 0 || index >= size){
throw new ArrayIndexOutOfBoundsException();
}else{
return data[index];
}
}
public int sizeof(){
return size;
}
public void clear(){
data = new int[10];
size = 0;
}
@Override
public String toString(){
StringBuilder str = new StringBuilder("[");
for(int i = 0 ;i < size ;i++){
str.append(data[i]).append(",");
}
String sb = str.toString();
if(size > 0){
sb= sb.substring(0,sb.length()-1);
}
return sb + "]";
}
}

Arrlist的重要方法重写的更多相关文章

  1. 【java开发】方法重写和方法重载概述

    类的继承   父类-子类 关键字 extends 新建一个父类 public class Person {     private String name;          private int ...

  2. 学习ASP.NET Web API框架揭秘之“HTTP方法重写”

    最近在看老A的<ASP.NET Web API 框架揭秘>,这本书对于本人现阶段来说还是比较合适的(对于调用已经较为熟悉,用其开发过项目,但未深入理解过很多内容为何可以这样“调用”).看到 ...

  3. 方法重写和方法重载;this关键字和super关键字

    1:方法重写和方法重载的区别?方法重载能改变返回值类型吗? 方法重写: 在子类中,出现和父类中一模一样的方法声明的现象. 方法重载: 同一个类中,出现的方法名相同,参数列表不同的现象. 方法重载能改变 ...

  4. 疯狂java学习笔记之面向对象(六) - 构造器重载、方法重载和方法重写

    一.方法重载(Overload): Java允许同一个类中定义多个同名方法,只要形参不一样就可以,如果同一个类中包含了两个或两个以上方法名相同的方法,但形参列表不同,则被成为方法重载(两同一异). 同 ...

  5. 用HashSet的add方法谈hashcode和equals方法重写

    本文主要通过用HashSet的add方法讲一下hashCode和equals方法重写.错误的地方望指正. 1.了解HashSet的add方法 了解一个方法的好办法是看源码,所以先看源码 private ...

  6. Java中实例方法,实例变量,静态方法,静态变量,final方法重写的问题,覆盖

    Java中只有非私有的实例方法能被重写,即实现多态,子类可以覆盖父类的方法,但是实例变量不能覆盖,若子类和父类均定义了同样名称的变量,则对于子类来说这是两个不同的变量,要想调用父类的变量必须显示去调用 ...

  7. Objective-c 类的继承 方法重写 方法重载

    一.类的继承 Objective-c中类的继承与C++类似,不同的是Objective-c不支持多重继承,一个类只能有一个父类,单继承使Objective-c的继承关系很简单,易于管理程序. Obje ...

  8. C++学习笔记24,方法重写与方法隐藏

    该博文仅用于交流学习.请慎用于不论什么商业用途.本博主保留对该博文的一切权利. 博主博客:http://blog.csdn.net/qq844352155 转载请注明出处: 方法重写.是指在子类中又一 ...

  9. java方法重写和super关键字

    //java方法重写和super关键字 //在继承中,其实就是子类定义了和父类同名的方法 //就是方法,属性都是相通的 //重写限制: //被子类重写的方法不能拥有比父类方法更加严格的权限 //sup ...

随机推荐

  1. v-charts简介

    一, v-charts简介 在使用 echarts 生成图表时,经常需要做繁琐的数据类型转化.修改复杂的配置项,v-charts 的出现正是为了解决这个痛点.基于 Vue2.0 和 echarts 封 ...

  2. matlab飞机飞行

    function donghua4 %首先建立一个飞机模型 %然后写一个旋转仿射矩阵 %利用仿射变换改变飞机方向 clear;clc;TR=[1 50 41;1 51 50;2 51 1;3 51 2 ...

  3. laravel中ajax,post传值问题

    //laravel中有CSRF保护 不加的话会出现419错误$.ajax({ url: '/admin/user/'+id, type: "POST", data: {'_toke ...

  4. 18B20驱动小经验

    在写命令时P14拉高在最后 在读命令时P14在拉低后拉高

  5. CTF大赛学习第一天!!!(学习中)

  6. iOS绘制坐标图,折线图-Swift

    坐标图,经常会在各种各样的App中使用,最常用的一种坐标图就是折线图,根据给定的点绘制出对应的坐标图是最基本的需求.由于本人的项目需要使用折线图,第一反应就是搜索已经存在的解决方案,因为这种需求应该很 ...

  7. 用Python绘制一个感兴趣是数学公式图

    下面是函数sin,cos函数的图像: 代码如下: import numpy as np import pylab as pl import matplotlib.font_manager as fm ...

  8. Linux 系统调用(system call)

    1 系统调用:(SYSTEM CALL) 操作系统(operating system)内核中有一组实现系统功能的过程,系统调用就是对上述过程的调用.程序员利用系统调用,向OS提出服务请求,由OS代为完 ...

  9. mysql配置外部允许外部连接

    1. 登录到mysql mysql -u root -p 2.进入到mysql 库中 use mysql 3.执行语句 update user set host=‘%’ where user=‘roo ...

  10. jQuary学习の四の遍历

    向上遍历DOM树: parent():返回被选元素的直接父元素 parents():返回被选元素的所有祖先元素(当后边参数存在时则表示其中与参数相同的祖先元素) parentsUntil()返回介于两 ...