zoukankan      html  css  js  c++  java
  • 设计一个泛型类orderedCollection

    设计一个泛型类orderedCollection,它存储的Comparable对象的集合(在数组中),以及该集合的当前大小。提供public方法isEmpty,makeEmpty,insert,remove,findMin和 findMax。

    finfMin和findMax分别返回该集合中最小的和最大T对象的引用(如果该集合为空,则返回null)

    /**
     * <p>
     * 设计一个泛型类orderedCollection,它存储的Comparable对象的集合(在数组中),
     * 以及该集合的当前大小。提供public方法isEmpty,makeEmpty,insert,remove,findMin和
     * findMax。finfMin和findMax分别返回该集合中最小的和最大T对象的引用(如果该集合为空,则返回null)
     * </p>
     *
     * @author wangchao
     *
     * @version 1.0.0
     *
     * @since 1.0.0
     *
     */
    public class OrderedCollection {
    	private Comparable[] obj;
    	private int length;
    
    	public int getLength() {
    		return obj.length;
    	}
    
    	public void setLength(int length) {
    		this.length = length;
    	}
    
    	public Comparable[] getObj() {
    		return obj;
    	}
    
    	public void setObj(Comparable[] obj) {
    		this.obj = obj;
    	}
    
    	public void makeEmpty() {
    		obj = new Comparable[] {};
    	}
    
    	public Comparable findMin() {
    		if (obj.length == 0) {
    			return null;
    		}
    		int min = 0;
    		for (int i = 1; i < obj.length; i++) {
    			if (obj[i].compareTo(obj[min]) <= 0) {
    				min = i;
    			}
    		}
    		return obj[min];
    	}
    
    	public Comparable findMax() {
    		if (obj.length == 0) {
    			return null;
    		}
    		int max = 0;
    		for (int i = 1; i < obj.length; i++) {
    			if (obj[i].compareTo(obj[max]) > 0) {
    				max = i;
    			}
    		}
    		return obj[max];
    	}
    
    	public boolean isEmpty() {
    		return obj.length > 0 ? false : true;
    	};
    
    	public void insert(Comparable o) {
    		// 扩展数组容量
    		Comparable[] temp = new Comparable[obj.length + 1];
    		// 拷贝原有数组
    		for (int i = 0; i < obj.length; i++) {
    			temp[i] = obj[i];
    		}
    		// 末位添加新元素
    		temp[obj.length] = o;
    		obj = temp;
    	}
    
    	public boolean isPresent(Comparable o) {
    		if (obj.length == 0) {
    			return false;
    		}
    		// 遍历判断
    		for (Comparable ob : obj) {
    			if (o.equals(ob))
    				return true;
    		}
    		return false;
    	}
    
    	/**
    	 * <p>
    	 * 此处写的很复杂,应该有更简单的方法实现
    	 * </p>
    	 */
    	public void remove(Comparable o) {
    		if (obj.length == 0) {
    			return;
    		}
    		int count = 0;
    		for (int i = 0; i < obj.length; i++) {
    			if (o.equals(obj[i])) {
    				obj[i] = null;
    				count++;
    			}
    		}
    
    		Comparable[] temp = new Comparable[obj.length - count];
    		int i = 0;
    		for (Comparable ob : obj) {
    			if (ob != null) {
    				temp[i] = ob;
    				i++;
    			}
    		}
    		obj = temp;
    	}
    
    	public static void main(String[] args) {
    		OrderedCollection oc = new OrderedCollection();
    		Comparable[] obj = new Comparable[] { 12, 4, 6, 2, 68 };
    		oc.setObj(obj);
    		System.err.println(oc.findMin());
    		System.err.println(oc.getLength());
    	}
    
    }
    

      

      

  • 相关阅读:
    css 画图形大全
    css 动画中 ease,seae-in,ease-in-out,ease-out,效果区别
    css3 常用动画 随笔
    OpenCV局部变形算法探究
    利用moment为基础,基于DOM实现一个多个倒计时同时进行的js库方便使用
    nodejs 中使用 mocha + should + jscoverage 生成 单元测试覆盖率报告
    AutoX安途杯中山大学程序设计校赛 G Stack Sort I
    理解原生JAVA AOP思想
    分享几个MFC下建立隐藏运行的程序的方法(不会出现黑色框)。
    发一个自己封装的PNG透明图片类。
  • 原文地址:https://www.cnblogs.com/wangchaoBlog/p/6076904.html
Copyright © 2011-2022 走看看