Java编程思想第11章答案(1)

1、

package ch11;
import java.util.*;
public class Gerbil {
static int counter;
private final long id=counter++;
int gerbilNumber;
Gerbil(int i){
	gerbilNumber=i;
}
void hop() {
	System.out.println(id);
	System.out.println("hop");
}
public static void main(String[] args) {
	ArrayList<Gerbil> g=new ArrayList<Gerbil>();
	for(int i=0;i<3;i++)
		g.add(new Gerbil(3));
	for(int i=0;i<3;i++)
		g.get(i).hop();
}
}

2、

package ch11;
import java.util.*;
public class SimpleCollection {
public static void main(String[] args) {
	Collection<Integer> c=new HashSet<Integer>();
	for(int i=0;i<5;i++)
		c.add(i);
	for(Integer b:c)
		System.out.println(b);
}
}

4、

package ch11;
import java.util.*;
public class DD {
static int i=0;
static String[] s= {"A","B","C","D"};
static String next() {
	if(i<=3) {
		return s[i++];
	}
	else {
		i=0;
		return s[i++];
	}
}
static void Use(Collection c) {
	for(int i=0;i<3;i++)
		c.add(DD.next());
}
public static void main(String[] args) {
	String[] s=new String[3];
	ArrayList<String> s2=new ArrayList<String>();
	LinkedList<String> s3=new LinkedList<String>();
	HashSet<String> s4=new HashSet<String>();
	LinkedHashSet<String> s5=new LinkedHashSet<String>();
	TreeSet<String> s6=new TreeSet<String>();
	for(int i=0;i<3;i++)
		s[i]=DD.next();
	Use(s2);
	Use(s3);
	Use(s4);
	Use(s5);
	Use(s6);
    for(int i=0;i<3;i++) {
    	System.out.print(s[i]);
    }
    System.out.println();
    System.out.println(s2);
    System.out.println(s3);
    System.out.println(s4);
    System.out.println(s5);
    System.out.println(s6);   
}
}

7、

package ch11;
import java.util.*;
class A{}
public class UseList {
static List<A> l=new ArrayList<A>();
public static void main(String[] args) {
	for(int i=0;i<5;i++)
	l.add(new A());
	List l2=l.subList(0,1);
	l.removeAll(l2);
	System.out.println(l);
}
}
8、
package ch11;
import java.util.*;
public class Gerbil {
static int counter;
private final long id=counter++;
int gerbilNumber;
Gerbil(int i){
	gerbilNumber=i;
}
static void hop(ArrayList<Gerbil> g) {
Iterator<Gerbil> i=g.iterator();
while(i.hasNext()) {
	Gerbil ge=i.next();
	System.out.println(ge.id);
}
}
public static void main(String[] args) {
	ArrayList<Gerbil> g=new ArrayList<Gerbil>();
	for(int i=0;i<3;i++)
		g.add(new Gerbil(3));
		hop(g);
}
}

11、

package ch11;
import java.util.*;
class C{
private static int i=0;
private final int id=i++;
public String toString() {
	return "the id is"+id;
}
}

public class UseCollection {
static void go(Collection<C> c) {
	Iterator<C> it=c.iterator();
	while(it.hasNext()) {
	    C ci=it.next();
		System.out.println(ci);
	}
}
static void adds(Collection<C> c) {
	for(int i=0;i<3;i++)
		c.add(new C());
}
public static void main(String[] args) {
	ArrayList<C> l1=new ArrayList<C>();
	LinkedList<C> l2=new LinkedList<C>();
	HashSet<C> s1=new HashSet<C>();
	TreeSet<C> s2=new TreeSet<C>();
	adds(l1);
	go(l1);
	adds(l2);
	go(l2);
	adds(s1);
	go(s1);//HashSet无序排列。
	//adds(s2);这个比较特殊,必须对放入的元素进行区分,否则会报错,以后再研究。
	//go(s2);
}
}

12、

package ch11;
import java.util.*;
public class UseList {
public static void main(String[] args) {
List<Integer> l1=new ArrayList<Integer>();
for(int i=0;i<9;i++)
	l1.add(i);
List<Integer> l2=new ArrayList<Integer>();
ListIterator<Integer> li=l1.listIterator(9);
while(li.hasPrevious())
	l2.add(li.previous());
System.out.println(l2);
}
}

14、

package ch11;
import java.util.*;
public class Link {
static LinkedList<Integer> li=new LinkedList<Integer>();
public static void main(String[] args) {
	for(int i=0;i<10;i++)
	li.add(i);
	for(int i=0;i<3;i++) {
		int l=li.size()/2;
		ListIterator<Integer> it=li.listIterator(l);
		it.add(i);
	}
	System.out.println(li);
}
}

15、

package ch11;
import java.util.*;
public class Try {
	public static void main(String[] args) {
		Stack<String> s=new Stack<String>();
		s.push("U");
		s.push("n");
		s.push("c");
		System.out.println(s.pop());
		System.out.println(s.pop());
		System.out.println(s.pop());
		s.push("e");
		s.push("r");
		s.push("t");
		System.out.println(s.pop());
		System.out.println(s.pop());
		System.out.println(s.pop());
		//and so on...
	}
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

returnadsss

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值