《Java语言程序设计》P327

题目要求使用数组来模拟实现ArrayList的一些方法,并要求可以根据实际长度来实现数组自动增长,这里只贴出LikeArrayList.java

测试方法已经在本地写过,有点杂乱就不再贴出。

缺陷:无法实现自增长;基于String为数组类型的设计,数组若为其他类型,有些方法会不能正常工作。

改进:判断数组类型,并作出相应的解决方案的写法已经想好,实现起来应该不难,但考虑到比较繁琐费时,不再添加。

Ps.LikeArrayList方法可以改写成:

    public void LikeArrayList() {
        Object[] ArrayLi = new Object[20];
        ArrayLiLike = ArrayLi;
    }

似乎没有什么变化,若实现自增长,可以尝试在LikeArrayList方法上做改动,还没想好解决方案。

话说回来,如果要实现自增长,为何不直接用java.util.ArrayList?

public class LikeArrayList {
    private Object[] ArrayLiLike = new Object[20];

    public void LikeArrayList() {

    }

    public void add(Object n){
        int m =0;
        for (int i = 0; i < ArrayLiLike.length; i++) {
            if(ArrayLiLike[i] == null){
                m = i;
                break;
            }
        }
        ArrayLiLike[m] = n;
    }

    public void add(int p , Object n){
        ArrayLiLike[p] = n;
    }

    public void clear(){
        for (int i = 0; i < ArrayLiLike.length; i++) {
            ArrayLiLike[i] = null;
        }
    }

    public boolean contains(Object h){
        boolean c = false;
        for (int i = 0; i < ArrayLiLike.length; i++) {
            if (ArrayLiLike[i] == h) {
                c = true;
            }
        }
        return c;
    }

    public Object get(int b){
        return ArrayLiLike[b];
    }

    public int indexOf(Object w){
        int a = 0;
        for (int i = 0; i < ArrayLiLike.length; i++) {
            if(ArrayLiLike[i] == w){
                a = i;
                break;
            }
        }
        return a;
    }

    public boolean isEmpty(){
        boolean is = true;
        for (int i = 0; i < ArrayLiLike.length; i++) {
            if(ArrayLiLike[i] != null){
                is = false;
                break;
            }
        }
        return is;
    }

    public int lastIndexOf(Object w){
        int a = 0;
        for (int i = 0; i < ArrayLiLike.length; i++) {
            if(ArrayLiLike[i] == w){
                a = i;
                continue;
            }
        }
        return a;
    }

    public boolean remove(Object re){
        boolean in = false;
        for (int i = 0; i < ArrayLiLike.length; i++) {
            if(ArrayLiLike[i] == re){
                in = true;
                ArrayLiLike[i] = null;
                break;
            }
        }
        return in;
    }

    public int size(){
        return ArrayLiLike.length+1;
    }

    public boolean remove(int re){
        boolean in = false;
        if (ArrayLiLike[re] != null){
            in = true;
            ArrayLiLike[re] = null;
        }else{
            in = false;
        }
        return in;
    }

    public Object set(int p, Object o){
        ArrayLiLike[p] = o;
        return ArrayLiLike[p];
    }

    public String toString(){
        String s = new String();
        for (int i = 0; i < ArrayLiLike.length; i++) {
            s += ArrayLiLike[i] + " ";
        }
        return s;
    }
}

Chp11 11.7的更多相关文章

  1. 地区sql

    /*Navicat MySQL Data Transfer Source Server : localhostSource Server Version : 50136Source Host : lo ...

  2. WinForm 天猫2013双11自动抢红包【源码下载】

    1. 正确获取红包流程 2. 软件介绍 2.1 效果图: 2.2 功能介绍 2.2.1 账号登录 页面开始时,会载入这个网站:https://login.taobao.com/member/login ...

  3. C++11特性——变量部分(using类型别名、constexpr常量表达式、auto类型推断、nullptr空指针等)

    #include <iostream> using namespace std; int main() { using cullptr = const unsigned long long ...

  4. CSS垂直居中的11种实现方式

    今天是邓呆呆球衣退役的日子,在这个颇具纪念意义的日子里我写下自己的第一篇博客,还望前辈们多多提携,多多指教! 接下来,就进入正文,来说说关于垂直居中的事.(以下这11种垂直居中的实现方式均为笔者在日常 ...

  5. C++ 11 多线程--线程管理

    说到多线程编程,那么就不得不提并行和并发,多线程是实现并发(并行)的一种手段.并行是指两个或多个独立的操作同时进行.注意这里是同时进行,区别于并发,在一个时间段内执行多个操作.在单核时代,多个线程是并 ...

  6. CSharpGL(11)用C#直接编写GLSL程序

    CSharpGL(11)用C#直接编写GLSL程序 +BIT祝威+悄悄在此留下版了个权的信息说: 2016-08-13 由于CSharpGL一直在更新,现在这个教程已经不适用最新的代码了.CSharp ...

  7. ABP(现代ASP.NET样板开发框架)系列之11、ABP领域层——仓储(Repositories)

    点这里进入ABP系列文章总目录 基于DDD的现代ASP.NET开发框架--ABP系列之11.ABP领域层——仓储(Repositories) ABP是“ASP.NET Boilerplate Proj ...

  8. C++11 shared_ptr 智能指针 的使用,避免内存泄露

    多线程程序经常会遇到在某个线程A创建了一个对象,这个对象需要在线程B使用, 在没有shared_ptr时,因为线程A,B结束时间不确定,即在A或B线程先释放这个对象都有可能造成另一个线程崩溃, 所以为 ...

  9. C++11网络编程

    Handy是一个简洁优雅的C++11网络库,适用于linux与Mac平台.十行代码即可完成一个完整的网络服务器. 下面是echo服务器的代码: #include <handy/handy.h&g ...

随机推荐

  1. Android ORM应用开发框架KJFrameForAndroid使用详解

    本文将为大家介绍一款Android ORM应用开发框架KJFrameForAndroid,很多时候我们也叫它KJLibrary. KJFrameForAndroid简介 KJFrameForAndro ...

  2. php导入excel

    使用phpexcelreader这个类文件来导入excel具体步骤: 先下载文件,然后引入phpexcelreader:下载地址:http://www.waaqi.com/wp-content/upl ...

  3. 使用ajaxfileupload.js实现文件上传

    ajaxFileUpload是一个异步上传文件的jQuery插件 语法:$.ajaxFileUpload([options]) options参数说明: 1.url  上传处理程序地址. 2,file ...

  4. css 背景透明文字(内容)不透明三种实现方法

    好久没写博客了.以前还想着最少一个月抽空写几篇.结果没做到O(∩_∩)O~~.好吧.现在努力,继续坚持. 看着以前写的东西,感觉自己在逐渐成长. 先上图: 本文主要记录如上图一样的.文字或内容不透明, ...

  5. asp.net webForm登录授权

    HttpCookie cookie; cookie = FormsAuthentication.GetAuthCookie(W3Account, isRemberMe); if (isRemberMe ...

  6. S3C6410开发板开发环境的搭建

    本节主要介绍了S3C6410开发板及OK6410开发板.OK6410开发板是基于ARM11处理器的S3C6410,采用“核心版+底板”结构 主要步骤如下:. OK6410开发板自带一个串口,PC也需要 ...

  7. @autoreleasepool在MRC和ARC中的区别

    对于@autoreleasepool {} (1)在ARC中会销毁所有在里面创建的对象,即使你用外面的Strong指针指向他 (2)在MRC中如果有外部的强指针指向,不会销毁对象,retainCoun ...

  8. HTML5和CSS3的一些新特性

    html5有哪些新特性.移除了那些元素?如何处理HTML5新标签的浏览器兼容问题?如何区分 HTML 和 HTML5? 新特性: 1. 拖拽释放(Drag and drop) 2. 语义化更好的内容标 ...

  9. C++ 基础算法之二分查找

    前提: 有序数组! int binary_search(int* a, int len, int goal) { ; ; while(low <= high) { ; if(a[middle] ...

  10. 2014优秀的好用的20款免费jQuery插件推荐

    2013 年最好的 20 款免费 jQuery 插件,世界买家网 www.buyerinfo.biz在这里分享给大家 这些插件对设计者和开发者都有很大的帮助,希望大家能够喜欢:) 现 今互联网市场上提 ...