Java集合框架2

8. 枚举(Enum)使用示例

声明一个枚举类型的简单形式如下:

访问类型 enum 枚举类名{值1[,值2,......]};

例8. 为枚举类添加辅助方法。

package set;

public enum Size {
    SMALL("S"), MEDIUM("M"), LARGE("L"), EXTRA_LARGE("XL");
    private String num;
    //定义私有构造器,无传入参数
    private Size(){
        this(null);
    }
    //定义私有构造器,传入字符串num作为参数
    private Size(String num){
        this.num = num;
    }
    //定义公有的getNum方法,获得num的值
    public String getNum(){
        return num;
    }
}

例9. 根据用户输入的型号输出相应的价格。

package set;

public enum size {
    SMALL(18.8), MEDIUM(26.8), LARGE(32.8), EXTRA_LARGE(40.8);
    private double cost;
    //定义私有构造器,无传入参数
    private size(){
        this(0);
    }
    //定义私有构造器,传入字符串num作为参数
    private size(double cost){
        this.cost = cost;
    }
    //定义公有的getNum方法,获得num的值
    public double getCost(){
        return cost;
    }
}
package set;
import java.util.Scanner;
public class showClothCost {

    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        size si;
        String type;
        boolean goon = true;
        System.out.println("请输入衣服型号,包括:SMALL,MEDIUM,LARGE,EXTRA_LARGE,空行表示结束!");
        while(goon){
            type = in.nextLine().toUpperCase();
            if(type.length()>0){
                si = (size)Enum.valueOf(size.class, type);
                System.out.println(type+"的价格为:"+si.getCost());
            }
            else
                goon = false;
        }
        in.close();
    }

}

程序运行结果为:

请输入衣服型号,包括:SMALL,MEDIUM,LARGE,EXTRA_LARGE,空行表示结束!
small
SMALL的价格为:18.8
medium
MEDIUM的价格为:26.8
large
LARGE的价格为:32.8
extra_large
EXTRA_LARGE的价格为:40.8

9. 枚举集(EnumSet)使用示例

EnumSet没有定义构造方法,要创建一个该类的对象,必须通过它的工厂方法来实现。用于创建一个枚举集的方法很多,而且都是静态方法,它们被称为工厂方法。

例10. 创建EnumSet示例。

下面的程序要使用上面例9中的size类。

package set;

import java.util.EnumSet;
import java.util.Iterator;

public class demoEnumSet {

    public static void main(String[] args) {
        EnumSet<size> enumSet = EnumSet.of(size.SMALL, size.MEDIUM);
        System.out.println("集合创建时拥有的元素:");
        showEnumSet(enumSet);
        System.out.println("补集拥有的元素:");
        showEnumSet(EnumSet.complementOf(enumSet));
        enumSet.add(size.LARGE);
        enumSet.add(size.EXTRA_LARGE);
        System.out.println("添加后拥有的元素为:");
        showEnumSet(enumSet);
        System.out.println("添加后补集拥有的元素为:");
        showEnumSet(EnumSet.complementOf(enumSet));

    }

    private static void showEnumSet(EnumSet<size> enumSet) {
        Iterator<size> it = enumSet.iterator();
        while(it.hasNext())
            System.out.print(it.next()+" ");
        System.out.println();
    }

}

程序运行结果如下:

集合创建时拥有的元素:
SMALL MEDIUM
补集拥有的元素:
LARGE EXTRA_LARGE
添加后拥有的元素为:
SMALL MEDIUM LARGE EXTRA_LARGE
添加后补集拥有的元素为:

10. 常用算法

例11. Collections中简单算法使用示例。

package set;
import java.util.*;
public class demoAlgorithom {

    public static void main(String[] args) {
        ArrayList<Integer> al = new ArrayList<Integer>();
        Integer elem;
        for(int i=0;i<10;i++)
            al.add((int)(Math.random()*1000));
        System.out.println("生成的数据为:");
        showList(al);

        elem = Collections.max(al);
        System.out.println("最大数据是:"+elem);

        elem = Collections.min(al);
        System.out.println("最小数据是:"+elem);

        Collections.reverse(al);
        System.out.println("反转后的数据为:");
        showList(al);

    }

    private static void showList(ArrayList<Integer> al) {
        for(Integer elem:al)
            System.out.print(elem+" ");
        System.out.println();

    }

}

程序运行结果如下:

生成的数据为:
767 235 533 336 563 474 654 881 733 342
最大数据是:881
最小数据是:235
反转后的数据为:
342 733 881 654 474 563 336 533 235 767 

11. 排序

例12. 排序示例。

package set;

import java.util.ArrayList;
import java.util.Collections;

public class demoSort {

    public static void main(String[] args) {
        ArrayList<Integer> al = new ArrayList<Integer>();
        Integer elem;
        for(int i=0;i<10;i++)
            al.add((int)(Math.random()*1000));
        System.out.println("生成的数据为:");
        showList(al);

        Collections.sort(al);
        System.out.println("排序后的数据为:");
        showList(al);

    }

    private static void showList(ArrayList<Integer> al) {
        for(Integer elem:al)
            System.out.print(elem+" ");
        System.out.println();

    }

}

程序运行结果为:

生成的数据为:
967 847 714 896 288 836 784 994 923 749
排序后的数据为:
288 714 749 784 836 847 896 923 967 994 

12. 二分查找

例13. 二分查找示例。

package set;
import java.util.*;
public class demoBinSearch {

    public static void main(String[] args) {
        ArrayList<Integer> al = new ArrayList<Integer>();
        Integer key;
        boolean goon = true;
        int index;
        Scanner in = new Scanner(System.in);
        for(int i=0;i<10;i++)
            al.add((int)(Math.random()*1000));
        Collections.sort(al);
        System.out.println("排序后的数据为:");
        showList(al);
        System.out.println("请输入要查找的关键字,小于0表示结束!");
        while(goon){
            key = in.nextInt();
            if(key>0){
                index = Collections.binarySearch(al, key);
                if(index>=0)
                    System.out.println("关键字"+key+"的索引为:"+index);
                else
                    System.out.println("关键字"+key+"没找到!");
            }else
                goon = false;
        }
        in.close();
    }

    private static void showList(ArrayList<Integer> al) {
        for(Integer elem:al)
            System.out.print(elem+" ");
        System.out.println();

    }

}

程序运行结果为:

排序后的数据为:
60 76 192 213 303 381 409 761 858 931
请输入要查找的关键字,小于0表示结束!
60
关键字60的索引为:0
381
关键字381的索引为:5
100
关键字100没找到!
-1

13. 向量类(Vector)使用示例

例14. Vector使用示例。

package set;
import java.util.*;
public class demoVector {

    public static void main(String[] args) {
        Vector<String> v = new Vector<String>(4);
        v.add("Test0");
        v.add("Test1");
        v.add("Test0");
        v.add("Test2");
        v.add("Test2");
        System.out.println("向量中的元素为:");
        showVector(v);
        v.remove("Test0");
        v.remove(0);
        System.out.println("现在向量中元素个数为:"+v.size());
        System.out.println("删除后向量中的元素为:");
        showVector(v);
    }

    private static void showVector(Vector<String> v) {
        Iterator it = v.iterator();
        while(it.hasNext())
            System.out.print(it.next()+" ");
        System.out.println();

    }

}

程序的运行结果为:

向量中的元素为:
Test0 Test1 Test0 Test2 Test2
现在向量中元素个数为:3
删除后向量中的元素为:
Test0 Test2 Test2

14. 栈(Stack)使用示例

例15. 利用栈将字符串逆序输出。

package set;
import java.io.*;
import java.util.*;
public class reverseString {

    public static void main(String[] args) {
        FileInputStream fin;
        FileOutputStream fout;
        Stack<Character> stack = new Stack<Character>();
        char ch;
        try {
            fin = new FileInputStream(FileDescriptor.in);
            System.out.println("请输入一行字符:");
            while((ch=(char)fin.read())!=‘\r‘)
                stack.push(ch);
            fin.close();
            System.out.println("逆序输出为:");
            fout= new FileOutputStream(FileDescriptor.out);
            while(!stack.empty())
                fout.write(stack.pop());
            fout.close();
        } catch (Exception e) {
            System.out.println("输入输出流有误!");
        }

    }

}

程序运行结果为:

请输入一行字符:
Hello world!
逆序输出为:
!dlrow olleH
时间: 2024-08-06 16:04:46

Java集合框架2的相关文章

Java—集合框架List

集合的概念 现实生活中:很多的事物凑在一起 数学中的集合:具有共同属性的事物的总和 Java中的集合类:是一种工具类,就像是容器,存储任意数量的具有共同属性的对象 集合的作用 在类的内部,对数据进行组织(针对作用与意义一样的属性,将他们放到一个集合中) 简单而快速的搜索大数量的条目 有的集合接口,提供了一系列排列有序的元素,并且可以在序列中快速的插入或删除有关元素 有的集合接口,提供了映射关系,可以通过关键字(key)去快速查找到对应的唯一对象,而这个关键字可以是任意类型 与数组相比 数组的长度

《深入理解Java集合框架》系列文章

Introduction 关于C++标准模板库(Standard Template Library, STL)的书籍和资料有很多,关于Java集合框架(Java Collections Framework, JCF)的资料却很少,甚至很难找到一本专门介绍它的书籍,这给Java学习者们带来不小的麻烦.我深深的不解其中的原因.虽然JCF设计参考了STL,但其定位不是Java版的STL,而是要实现一个精简紧凑的容器框架,对STL的介绍自然不能替代对JCF的介绍. 本系列文章主要从数据结构和算法层面分析

JAVA集合框架

收藏 查看我的收藏 146有用+1 56 编辑 Java,是由Sun Microsystems公司于1995年5月推出的Java程序设计语言和Java平台的总称.用Java实现的HotJava浏览器(支持Java applet)显示了Java的魅力:跨平台.动态的Web.Internet计算.从此,Java被广泛接受并推动了Web的迅速发展,常用的浏览器现在均支持Java applet.集合框架是为表示和操作集合而规定的一种统一的标准的体系结构.任何集合框架都包含三大块内容:对外的接口.接口的实

我所理解Java集合框架的部分的使用(Collection和Map)

所谓集合,就是和数组类似--一组数据.java中提供了一些处理集合数据的类和接口,以供我们使用. 由于数组的长度固定,处理不定数量的数据比较麻烦,于是就有了集合. 以下是java集合框架(短虚线表示接口,长虚线表示抽象类,实线表示类,箭头表示实现接口或者继承)(在网络上找的图,不知道原作者,侵权请联系我删除)(总之,关系很复杂,所以不用记得这个图,只是用来吓吓人而已的). 下面贴上个人理解之精简版之Collection(集)和Map(地图?暂且这么理解吧),话说思维导图蛮好用,以下是两幅思维导图

【Java集合源码剖析】Java集合框架

Java集合工具包位于package java.util下.包含了一些常用的数据结构,如数组.链表(单/双向).树.栈.队列.哈希表等. Java集合框架大致可分为五部分:List列表.Set集合.Map映射.迭代器(Iterator.Enumeration).工具类(Arrays.Collections). Java集合类的整体框架如下: 如图,Java集合类大致分为两大类:Collection和Map. Collection主要包括两部分:List和Set. List接口通常表示一个列表(数

Java集合框架总结(3)——TreeSet类的排序问题

Java集合框架总结(3)--TreeSet类的排序问题 TreeSet支持两种排序方法:自然排序和定制排序.TreeSet默认采用自然排序. 1.自然排序 TreeSet会调用集合元素的compareTo(Object obj)方法来比较元素之间大小关系,然后将集合元素按升序排列,这种方式就是自然排序.(比较的前提:两个对象的类型相同). java提供了一个Comparable接口,该接口里定义了一个compareTo(Object obj)方法,该方法返回一个整数值,实现该接口的类必须实现该

2016.3.9-3.10(java集合框架)

3.9 集合框架有什么作用? 集合框架其主要功能是用来将存储的数据以某种结构组织,并以特定的方式来访问这些数据. Java集合框架中有哪些存储方式? Java集合框架中的对象容器,按照对象在其中的存储方式,分为Set.List.和Map三种类型. Set类型对象没有顺序,且不能重复: List类型对象容器中的对象按照索引顺序排序,而且可以有重复的对象: Map类型对象容器中的元素包含一对“键对象-值对象”映射,其中键对象不能重复,值对象可以重复. 以上三种存储方式对应Java集合框架中Set.L

java集合框架22

思想:在面向对象的思想里,一种数据结构被认为是一种容器.在本质上来讲是一个类,提供方法支持查找,插入和删除等等操作. Java集合框架支持以下俩种类型的容器: 存储一个元素集合,简称为集合Collection 存储键值对,称为图Map 集合collection 三种主要类型 : 规则集(set) , 线型表(List) , 队列(Queue) set: 存储一组不重复的数据 List: 存储由元素构成的有序集合 Queue: 存储先进先出方式处理的对象 细说Collection接口: 它是处理对

Java集合框架的知识总结

说明:面试准备,写的挺不错的. 转载地址: http://www.cnblogs.com/zhxxcq/archive/2012/03/11/2389611.html 1.综述 所有集合类都位于java.util包下.集合中只能保存对象(保存对象的引用变量).(数组既可以保存基本类型的数据也可以保存对象). 当我们把一个对象放入集合中后,系统会把所有集合元素都当成Object类的实例进行处理.从JDK1.5以后,这种状态得到了改进:可以使用泛型来限制集合里元素的类型,并让集合记住所有集合元素的类

Java集合框架之泛型

广州疯狂软件教育Java培训,iOS培训分享 泛型:1.5版本以后出现的新特性.用于解决安全问题,是一个安全机制. 好处: 1.将运行时期出现问题ClassCaseException,转移到了编译时期. 2.方便与程序员解决问题.让运行时事情减少,安全. 3.避免了强制类型转换 泛型格式:通过<>来定义要操作的引用数据类型 什么时候写泛型: 在集合框架中和常见 只要见到<>就要定义泛型 import java.util.Comparator; import java.util.It