面向对象数组操作

封装面向对象数组,并且支持有序和无序,查询元素分为顺序查找和二分法。

  1 /**
  2  * @ClassName: MyArray
  3  * @Description: 封装自己数组
  4  * @author dongye
  5  * @date 2016年3月1日 上午9:28:40
  6  *
  7  */
  8 public class MyArray {
  9     private long[] arr;
 10     //有效长度
 11     private int elements;
 12
 13     public MyArray(){
 14         arr=new long[50];
 15     }
 16
 17     public MyArray(int maxsize){
 18         arr=new long[maxsize];
 19     }
 20
 21     /**
 22      * @Description:无序插入
 23      * @return void    返回类型
 24      * @author dongye
 25      * @date 2016年3月1日 上午9:31:01
 26      */
 27     public void insert(long value) {
 28         arr[elements]=value;
 29         elements++;
 30     }
 31
 32     /**
 33      *
 34     * @Title: insertOrder
 35     * @Description: 有序插入
 36     * @return void    返回类型
 37     * @author dongye
 38     * @date 2016年3月1日 上午10:10:52
 39     * @throws
 40      */
 41     public void insertOrder(long value) {
 42         int i;
 43         for (i = 0; i < elements; i++) {
 44             if(arr[i]>value){
 45                 break;
 46             }
 47         }
 48         for(int j=elements;j>i;j--){
 49             arr[j]=arr[j-1];
 50         }
 51         arr[i]=value;
 52         elements++;
 53     }
 54
 55
 56
 57
 58     /**
 59      *
 60     * @Title: display
 61     * @Description: 显示元素
 62     * @author dongye
 63     * @date 2016年3月1日 上午9:32:25
 64      */
 65     public void display(){
 66         System.out.print("[");
 67         for (int i = 0; i <elements; i++) {
 68             System.out.print(arr[i]+" ");
 69         }
 70         System.out.println("]");
 71     }
 72
 73     /**
 74      *
 75     * @Description: 查找数据(线性查找) 对于无序有序都可以
 76     * @author dongye
 77     * @date 2016年3月1日 上午9:35:37
 78      */
 79     public int search(long value){
 80         int i;
 81         for (i = 0; i < elements; i++) {
 82             if(value==arr[i]){
 83                 break;
 84             }
 85         }
 86         if(i==elements){
 87             i=-1;
 88         }
 89         return i;
 90     }
 91
 92     public int binarySearch(long value){
 93         int middle=0;
 94         int low=0;
 95         int pow=elements;
 96         while(true){
 97             middle=(low+pow)/2;
 98             System.out.println(low+":"+pow);
 99             System.out.println(middle);
100             if(value==arr[middle]){
101                 return middle;
102             }else if(low>pow){
103                 return -1;
104             }else{
105                 if(value>arr[middle]){
106                     low=middle+1;
107                 }else{
108                     pow=middle-1;
109                 }
110             }
111         }
112     }
113
114     /**
115      *
116     * @Description: 根据索引查找元素
117     * @return long    返回类型
118     * @author dongye
119     * @date 2016年3月1日 上午9:40:59
120      */
121     public long get(int index){
122         if(index>=elements||index<=0){
123             throw new ArrayIndexOutOfBoundsException();
124         }else{
125             return arr[index];
126         }
127     }
128
129     /**
130      * @Title: delete
131      * @Description: 删除数据
132      * @return void    返回类型
133      * @author dongye
134      * @date 2016年3月1日 上午9:41:57
135      * @throws
136      */
137     public void delete(int index) {
138         if(index>=elements||index<=0){
139             throw new ArrayIndexOutOfBoundsException();
140         }else{
141             for (int i = index; i < elements; i++) {
142                 arr[index]=arr[index+1];
143                 elements--;
144             }
145         }
146     }
147
148     /**
149      *
150     * @Title: change
151     * @Description: 更新数据
152     * @return void    返回类型
153     * @author dongye
154     * @date 2016年3月1日 上午9:45:27
155     * @throws
156      */
157     public void change(int index,int newValue){
158         if(index>=elements||index<=0){
159             throw new ArrayIndexOutOfBoundsException();
160         }else{
161             arr[index]=newValue;
162         }
163     }
164
165
166 }
时间: 2024-08-28 00:02:13

面向对象数组操作的相关文章

PHP:数组操作函数array_count_values()的实现

    PHP作为一门弱类型的脚本语言,其变量无需声明,即用即得,其数组更是与其他强类型语言相差巨大,比如PHP数组中的关联键和数值键,其中最有趣的莫过于关联键了,这是在C++或JAVA中无法见到的,而且PHP还提供诸多强大的数组操作函数,比如   array_values()//可以剥离数组中的关联键和数值键,或得有其元素的值所组成的数组 array_keys()//获得所有的关联键和数值键  利用这两个函数就可以非常方便简单的实现  array_count_values()函数  思路就是先

PHP内核探索之变量(4) - 数组操作

上一节(PHP内核探索之变量(3)- hash table),我们已经知道,数组在PHP的底层实际上是HashTable(链接法解决冲突),本文将对最常用的函数系列-数组操作的相关函数做进一步的跟踪. 本文主要内容: PHP中提供的数组操作函数 数组操作函数的实现 结语参考文献 一.PHP中提供的数组操作函数 可以说,数组是PHP中使用最广泛的数据结构之一,正因如此,PHP为开发者提供了丰富的数组操作函数(参见http://cn2.php.net/manual/en/ref.array.php

PHP:常用PHP数组操作函数

php为我们提供了丰富的数组操作函数,用这些函数可以非常方便的实现我们所想实现的功能. 添加和删除数组元素 添加元素的方法 array_unshift(array array,mixed var [,mixed var...]) 在数组头添加元素,所有的数值键会被相应的修改,但关联键不会受到影响 array_push(array array,mixed var [,mixed var.....]) 在数组尾添加元素 删除数组元素的方法 array_shift(array array) 删除数组头

js数组操作

js数组操作大全(转) shift:删除原数组第一项,并返回删除元素的值:如果数组为空则返回undefined var a = [1,2,3,4,5]; var b = a.shift(); //a:[2,3,4,5] b:1 unshift:将参数添加到原数组开头,并返回数组的长度 var a = [1,2,3,4,5]; var b = a.unshift(-2,-1); //a:[-2,-1,1,2,3,4,5] b:7 注:在IE6.0下测试返回值总为undefined,FF2.0下测试

js数组操作常用方法(转自:http://www.jbxue.com/article/js/20224.html)

js数组操作常用方法,包括数组的创建.数组的元素的访问.数组元素的删除.数组的拷贝等. 原文参考自:http://www.jbxue.com/article/js/20224.html 在jquery中处理JSON数组的情况中遍历用到的比较多,但是用添加移除这些好像不是太多. 今天试过json[i].remove(),json.remove(i)之后都不行,看网页的DOM对象中好像JSON数据是以数组的形式出现的,查阅了下相关JS中数组的操作一试果然很爽.记录下来.1.数组的创建 var arr

JavaScript 数组操作

<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>数组操作</title> </head> <body> <script type="text/javascript"> //定义数组 var arry = [0,1,2,3,5,6,7,8]; //获取

JavaScript中常见的数组操作函数及用法

昨天写了个帖子,汇总了下常见的JavaScript中的字符串操作函数及用法.今天正好有时间,也去把JavaScript中常见的数组操作函数及用法总结一下,这样方便大家准备参考.如果恰好你也在准备各种笔试,希望对你有所帮助.同时,也欢迎补充. 1.数组创建 创建数组应该是最简单的了,有用数组字面量创建和数组构造函数两种方法,见下: var array1 = new Array(); var array2 = []; 上面是创建数组的最常见的两种方法,其中第二种方法因为简单直观而被开发者推崇.其中,

js基础复习---数组操作

<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <meta name="keywords" content="js数组操作"> <meta name="description" content="js基础之数组api练习"> <title

js中数组操作

var selectedCodeArray = []; var num = $.inArray(值, selectedCodeArray)  //值在数组中的位置 selectedCodeArray.push(值码); selectedCodeArray.splice(num, 1);//从数组中删除 js中数组操作,布布扣,bubuko.com