• 201521123027 <java程序设计>第七周学习总结


    1.本周学习总结

    2.书面作业

    Q1.ArrayList代码分析
    1.1 解释ArrayList的contains源代码
    答:

    源代码:
    //contains()方法
    public boolean contains(Object o) {
        return indexOf(o) >= 0;
    }
    
    //indexOf()方法
    public int indexOf(Object o) {
        if (o == null) {
            for (int i = 0; i < size; i++)
                if (elementData[i]==null)
                    return i;
        } else {
            for (int i = 0; i < size; i++)
                if (o.equals(elementData[i]))
                    return i;
        }
        return -1;
    }
    
    分析;在indexOf()方法中对传进来的值o判断是否为null,因为值o若为null,则不可以使用equals进行比较。如果找到了值o,则返回对应的数组下标;如果满意找到,则返回-1,那么contains()方法就会返回false。
    

    1.2 解释E remove(int index)源代码
    答:

    源代码:
    //remove代码
    public E remove(int index) {
        rangeCheck(index);
    
        modCount++;
        E oldValue = elementData(index);
    
        int numMoved = size - index - 1;
        if (numMoved > 0)
            System.arraycopy(elementData, index+1, elementData, index,
                             numMoved);
        elementData[--size] = null; // clear to let GC do its work
    
        return oldValue;
    }
    
    
    //rangeCheck代码
    private void rangeCheck(int index) {
        if (index >= size)
            throw new IndexOutOfBoundsException(outOfBoundsMsg(index));
    }
    
    分析:首先在remove()方法中调用rangeCheck()方法,是用来判断传入的index是否超过size,若超过,则抛出IndexOutOfBoundsException异常。然后这个remove()方法就是将对应下标的元素取出,再将后面的元素全部往前移一位,将最后一位,即size-1的位置置null。
    

    1.3 结合1.1与1.2,回答ArrayList存储数据时需要考虑元素的类型吗?

    答:不需要;因为其参数为object类型的对象,而object类是所有类的父类,所以说无论元素是什么类型,ArrayList都可以存储。
    

    1.4 分析add源代码,回答当内部数组容量不够时,怎么办?
    答:

    源代码:
    //add代码
    public boolean add(E e) {
        ensureCapacityInternal(size + 1); 
        elementData[size++] = e;
        return true;
    
    //ensureCapacityInternal代码
    private void ensureCapacityInternal(int minCapacity) {
        if (elementData == DEFAULTCAPACITY_EMPTY_ELEMENTDATA) {
            minCapacity = Math.max(DEFAULT_CAPACITY, minCapacity);
        }
    
        ensureExplicitCapacity(minCapacity);
    }
        modCount++;
        // overflow-conscious code
        if (minCapacity - elementData.length > 0) 
            grow(minCapacity);
    }   
    }
    
    //grow代码
     private void grow(int minCapacity) {
        // overflow-conscious code
        int oldCapacity = elementData.length;
        int newCapacity = oldCapacity + (oldCapacity >> 1); 
        if (newCapacity - minCapacity < 0)
            newCapacity = minCapacity;
        if (newCapacity - MAX_ARRAY_SIZE > 0)
            newCapacity = hugeCapacity(minCapacity);
        // minCapacity is usually close to size, so this is a win:
        elementData = Arrays.copyOf(elementData, newCapacity);
    }   
    
    分析:首先在add()方法中调用ensureCapacityInternal(),用来调整List的容量;如果超过了容量,则要调用grow()方法,int newCapacity = oldCapacity + (oldCapacity >> 1);就是增加原来容量的一半,即新容量为为旧容量的1.5倍; elementData = Arrays.copyOf(elementData, newCapacity);将旧数组中的数据拷贝至新数组中,说明增加容量不是在旧数组的基础上增加的,而是直接引用了一个全新的数组。
    

    1.5 分析private void rangeCheck(int index)源代码,为什么该方法应该声明为private而不声明为public?
    答:

    源代码:
    private void rangeCheck(int index) {
        if (index >= size)
            throw new IndexOutOfBoundsException(outOfBoundsMsg(index));
    }  
    
    分析:因为rangeCheck()方法只需要判断数组是否越界,没有其他的作用,外部不需要对它进行修改或者访问,所以说声明应为private。
    

    Q2.HashSet原理
    2.1 将元素加入HashSet(散列集)中,其存储位置如何确定?需要调用那些方法?

    首先调用hashCode方法计算出待存储对象的散列码,即hashCode值,作为存储的位置的依据找到相应的位置;若该位置有其他元素,则调用equals方法与已有元素进行比较。若结果为false,则将该元素插入;若结果为true,则用新的值替换旧的值。
    

    Q3.ArrayListIntegerStack
    题集jmu-Java-05-集合之5-1 ArrayListIntegerStack
    3.1 比较自己写的ArrayListIntegerStack与自己在题集jmu-Java-04-面向对象2-进阶-多态、接口与内部类中的题目5-3自定义接口ArrayIntegerStack,有什么不同?(不要出现大段代码)
    答:

    // ArrayListIntegerStack代码
    public ArrayListIntegerStack() {
    		list = new ArrayList<Integer>();
    	}
    
    //ArrayIntegerStack代码
    public ArrayIntegerStack(int n) {
    		arr=new Integer[n];
    	}
    

    不同点:

    (1)ArrayListIntegerStack是用ArrayList实现栈,而ArrayIntegerStack是用Integer数组实现;
    (2)当存入的数据足够多时,ArrayIntegerStack会出现栈满的情况,而ArrayListIntegerStack不会。因为ArrayList会在空间用完的状况下自动扩充容量;
    (3)ArrayIntegerStack需要用到top指针进行出栈、入栈等操作,而ArrayListIntegerStack不需要,可直接调用List中的方法。
    

    3.2 简单描述接口的好处.

    好处是使用一个接口可以操作不同的类,比如3-1中ArrayListIntegerStack和ArrayIntegerStack都继承了IntegerStack接口,我们可以根据我们的需求通过不同的方式去实现相同的目的。
    

    Q4.Stack and Queue
    4.1 编写函数判断一个给定字符串是否是回文,一定要使用栈,但不能使用java的Stack类(具体原因自己搜索)。请粘贴你的代码,类名为Main你的学号。

    import java.util.*;
    
    interface StringStack{
        public String push(String item);//如item为null,则不入栈直接返回null。如栈满,也返回null.
        public String pop();//出栈,如为空,则返回null.
    }
    class ArrayListStringStack implements StringStack{
        private List<String> list;
        
        public ArrayListStringStack() {
            list=new ArrayList<String>();
        }
        @Override
        public String push(String item) {
            // TODO Auto-generated method stub
            if(item==null)
                return null;
            list.add(item);
            return item;
        }
    
        @Override
        public String pop() {
            // TODO Auto-generated method stub
            if(list.isEmpty())
                return null;
            return list.remove(list.size()-1);
        }
    
    }
    public class Main201521123027 {
        public static void main(String[] args) {
            // TODO Auto-generated method stub
            Scanner in=new Scanner(System.in);
            StringStack stack=new ArrayListStringStack();
            String m=in.next();
            int j=1;
            for(int i=0;i<m.length();i++)
            {
                stack.push(String.valueOf(m.charAt(i)));
            }
            for(int i=0;i<m.length();i++)
            {
                if(String.valueOf(m.charAt(i)).equals(stack.pop()))
                	j=1;//若相同,则j=1
                else
                {
                    j=0;
                    break;//若有一个不同,则令j=0,并且跳出循环
                }
            }
            if(j==1)System.out.println("Yes!");
            else System.out.println("No!");
            }
    
    }
    

    4.2 题集jmu-Java-05-集合之5-6 银行业务队列简单模拟。(不要出现大段代码)

    入队:
    for (int i = 0; i < n; i++) {
    			int number = in.nextInt();
    			if (number % 2 == 0) B.add(number);
    			else A.add(number);
    		}
    出队:
    while(!A.isEmpty() || !B.isEmpty())
    		{
    			Integer a1 = A.poll();
    			if(a1 != null){
    				if(B.isEmpty() && A.isEmpty()) 
    					System.out.print(a1);
    				else
    					System.out.print(a1 + " ");	
    			}
    			
    			Integer a2 = A.poll();
    			if(a2 != null){
    				if(B.isEmpty() && A.isEmpty())
    					System.out.print(a2);
    				else 
    					System.out.print(a2 + " ");	
    			}
    			Integer b = B.poll();
    			if(b != null){
    				if(B.isEmpty() && A.isEmpty())
    					System.out.print(b);
    				else 
    					System.out.print(b + " ");
    			}
    			
    		}
    

    Q5.统计文字中的单词数量并按单词的字母顺序排序后输出
    题集jmu-Java-05-集合之5-2 统计文字中的单词数量并按单词的字母顺序排序后输出 (不要出现大段代码)
    5.1 实验总结

    关键代码:
    if (set.size() <= 10){
    			for (String string : set) {
    				System.out.println(string);
    			}
    		}else{
    			for (int i = 0; i < 10; i++) {
    				System.out.println(set.toArray()[i]);
    			}
    		}
    
    总结:此题中要求对对象按照字母顺序排序,所以要使用TreeSet进行排序。
    

    Q7.面向对象设计大作业-改进
    7.1 完善图形界面(说明与上次作业相比增加与修改了些什么)
    7.2 使用集合类改进大作业

    (还在研究中)

    3.码云上代码提交记录及PTA实验总结

    3.1码云代码提交记录

  • 相关阅读:
    iOS开发_当一个控件被添加到父控件中会调用
    iOS_判断应用在前台还是后台
    iOS开发_ SDWebImage先下载图片保存起来,需要时再调用
    WARNING ITMS90901: "Missing fullscreen support for the latest iPad mini display.
    iOS开发_显示带HTML标签的富文本
    iOS开发_WKWebView隐藏滚动条
    iOS_获取应用当前定位授权状态
    iOS开发_判断字符串是否为空的处理
    UIAlertController和UIActivityViewController在ipad中的兼容性问题
    npm run serve报错提示js堆内存不足
  • 原文地址:https://www.cnblogs.com/DevilRay/p/6681628.html
Copyright © 2020-2023  润新知