Chp11 11.7
《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的更多相关文章
- 地区sql
/*Navicat MySQL Data Transfer Source Server : localhostSource Server Version : 50136Source Host : lo ...
- WinForm 天猫2013双11自动抢红包【源码下载】
1. 正确获取红包流程 2. 软件介绍 2.1 效果图: 2.2 功能介绍 2.2.1 账号登录 页面开始时,会载入这个网站:https://login.taobao.com/member/login ...
- C++11特性——变量部分(using类型别名、constexpr常量表达式、auto类型推断、nullptr空指针等)
#include <iostream> using namespace std; int main() { using cullptr = const unsigned long long ...
- CSS垂直居中的11种实现方式
今天是邓呆呆球衣退役的日子,在这个颇具纪念意义的日子里我写下自己的第一篇博客,还望前辈们多多提携,多多指教! 接下来,就进入正文,来说说关于垂直居中的事.(以下这11种垂直居中的实现方式均为笔者在日常 ...
- C++ 11 多线程--线程管理
说到多线程编程,那么就不得不提并行和并发,多线程是实现并发(并行)的一种手段.并行是指两个或多个独立的操作同时进行.注意这里是同时进行,区别于并发,在一个时间段内执行多个操作.在单核时代,多个线程是并 ...
- CSharpGL(11)用C#直接编写GLSL程序
CSharpGL(11)用C#直接编写GLSL程序 +BIT祝威+悄悄在此留下版了个权的信息说: 2016-08-13 由于CSharpGL一直在更新,现在这个教程已经不适用最新的代码了.CSharp ...
- ABP(现代ASP.NET样板开发框架)系列之11、ABP领域层——仓储(Repositories)
点这里进入ABP系列文章总目录 基于DDD的现代ASP.NET开发框架--ABP系列之11.ABP领域层——仓储(Repositories) ABP是“ASP.NET Boilerplate Proj ...
- C++11 shared_ptr 智能指针 的使用,避免内存泄露
多线程程序经常会遇到在某个线程A创建了一个对象,这个对象需要在线程B使用, 在没有shared_ptr时,因为线程A,B结束时间不确定,即在A或B线程先释放这个对象都有可能造成另一个线程崩溃, 所以为 ...
- C++11网络编程
Handy是一个简洁优雅的C++11网络库,适用于linux与Mac平台.十行代码即可完成一个完整的网络服务器. 下面是echo服务器的代码: #include <handy/handy.h&g ...
随机推荐
- tips of my ubuntu 16.04 LTS
update_0 : sudo .../idea.sh 才会把idea安装上,不加sudo也会启动,但是不会在开始菜单中找到程序. ---------------------------------- ...
- OC NSString 基本操作(用到补充持续更新)
1.将字符串拆分成数组 NSString *string = @"1,2,3,4"; NSArray *array = [string componentsSeparatedByS ...
- CPU与内存的那些事
下面是网上看到的一些关于内存和CPU方面的一些很不错的文章. 整理如下: 转: CPU的等待有多久? 原文标题:What Your Computer Does While You Wait 原文地址: ...
- 【重要!】告K2老客户书
K2近期升级优化了售后支持系统,以便能更好的为亲爱的老客户们答疑解惑,比如:“老妈和老婆掉水里先救谁”.“中午吃啥晚上吃啥”.“技术男怎么学会撩妹”……这些问题,统统不会告诉你.售后TEAM作为一支专 ...
- Const(常量)与readonly(只读)的区别
const与readonly定义的值都不能更改,但它们到底有哪些异同点呢? Const ² Const是常量的意思,其定义的变量只能读取不能更改,且只能在定义时初始化,不能在构造函数与其它属性与方法中 ...
- 使用keytool生产jks证书
使用JDK中的keytool生成服务器证书 1.创建服务器KeyStorekeytool -genkey -alias server_jks_cennavi -keyalg RSA -keystor ...
- BAE hibernate c3p0数据库连接池
根据BAE官方文档:bae是不支持连接池的,但今天试验却能实现hibernate c3p0连接池,避免mysql连接超时 hibernate主配置文件hibernate.cfg.xml代码 <! ...
- [小菜随笔]新手使用appium+python进行自动化测试过程中webdriver.Remote报错的错误分析方法(带实例)
很多人刚开始使用python+appium去执行APP自动化的时候经常会遇到webdriver.Remote,报错位置指向都是driver = webdriver.Remote('http://127 ...
- 【转】Matlab练习程序(各向异性扩散)
http://www.cnblogs.com/tiandsp/archive/2013/04/18/3029468.html 主要是用来平滑图像的,克服了高斯模糊的缺陷,各向异性扩散在平滑图像时是保留 ...
- 浅谈sizeof
问题:1)sizeof是函数吗:2)sizeof功能:3)具体问题下sizeof值 1)sizeof不是函数,是C语言的一个关键字 2)sizeof作为右值时,求①某个数据类型(sizeof(int) ...