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
Java集合框架2的更多相关文章
- Java集合框架List,Map,Set等全面介绍
Java集合框架的基本接口/类层次结构: java.util.Collection [I]+--java.util.List [I] +--java.util.ArrayList [C] +- ...
- Java集合框架练习-计算表达式的值
最近在看<算法>这本书,正好看到一个计算表达式的问题,于是就打算写一下,也正好熟悉一下Java集合框架的使用,大致测试了一下,没啥问题. import java.util.*; /* * ...
- 【集合框架】Java集合框架综述
一.前言 现笔者打算做关于Java集合框架的教程,具体是打算分析Java源码,因为平时在写程序的过程中用Java集合特别频繁,但是对于里面一些具体的原理还没有进行很好的梳理,所以拟从源码的角度去熟悉梳 ...
- Java 集合框架
Java集合框架大致可以分为五个部分:List列表,Set集合.Map映射.迭代器.工具类 List 接口通常表示一个列表(数组.队列.链表 栈),其中的元素 可以重复 的是:ArrayList 和L ...
- Java集合框架之map
Java集合框架之map. Map的主要实现类有HashMap,LinkedHashMap,TreeMap,等等.具体可参阅API文档. 其中HashMap是无序排序. LinkedHashMap是自 ...
- 22章、Java集合框架习题
1.描述Java集合框架.列出接口.便利抽象类和具体类. Java集合框架支持2种容器:(1) 集合(Collection),存储元素集合 (2)图(Map),存储键值对.
- Java集合框架实现自定义排序
Java集合框架针对不同的数据结构提供了多种排序的方法,虽然很多时候我们可以自己实现排序,比如数组等,但是灵活的使用JDK提供的排序方法,可以提高开发效率,而且通常JDK的实现要比自己造的轮子性能更优 ...
- (转)Java集合框架:HashMap
来源:朱小厮 链接:http://blog.csdn.net/u013256816/article/details/50912762 Java集合框架概述 Java集合框架无论是在工作.学习.面试中都 ...
- Java集合框架
集合框架体系如图所示 Java 集合框架提供了一套性能优良,使用方便的接口和类,java集合框架位于java.util包中, 所以当使用集合框架的时候需要进行导包. Map接口的常用方法 Map接口提 ...
- Java集合框架(常用类) JCF
Java集合框架(常用类) JCF 为了实现某一目的或功能而预先设计好一系列封装好的具有继承关系或实现关系类的接口: 集合的由来: 特点:元素类型可以不同,集合长度可变,空间不固定: 管理集合类和接口 ...
随机推荐
- Ubuntu16.04下Kylin的安装与配置
一.系统环境 kylin的安装配置并不像官方文档中描述的那样简单,复杂的原因在于hadoop,hive,hbase,kylin的版本一定要兼容,不然就会出现各种奇怪的错误.以下各软件版本可以成功运行k ...
- 牛客练习赛1 B - 树
链接:https://www.nowcoder.com/acm/contest/2/B来源:牛客网 题目描述 shy有一颗树,树有n个结点.有k种不同颜色的染料给树染色.一个染色方案是合法的,当且仅当 ...
- [js]面向对象编程
一.js面向对象基本概念 对象:内部封装.对外预留接口,一种通用的思想,面向对象分析: 1.特点 (1)抽象 (2)封装 (3)继承:多态继承.多重继承 2.对象组成 (1)属性: 任何对象都可以添加 ...
- Jenkins的Pipeline脚本在美团餐饮SaaS中的实践
一.背景 在日常开发中,我们经常会有发布需求,而且还会遇到各种环境,比如:线上环境(Online),模拟环境(Staging),开发环境(Dev)等.最简单的就是手动构建.上传服务器,但这种方式太过于 ...
- [leetcode tree]96. Unique Binary Search Trees
Given n, how many structurally unique BST's (binary search trees) that store values 1...n? For examp ...
- CentOS系统php5.6安装ImageMagick处理webp格式图片
1.先安装webp yum install libwebp 2.编译安装ImageMagick 之前有过yum安装的先卸载 yum remove ImageMagick 我使用的是老版本ImageMa ...
- jQuery学习总结1
一.下载集CDN引入 1.1.官方下载 地址:http://jQuery.com/download/ jq自2.0版本开始,不再支持IE9一下浏览器:自3.0版本开始,针对移动端做了优化处理: 引入 ...
- 数据库中drop、delete与truncate的区别
数据库中drop.delete与truncate的区别 drop直接删掉表: truncate删除表中数据,再插入时自增长id又从1开始 :delete删除表中数据,可以加where字句. (1) D ...
- nginx与Lua执行顺序
Nginx顺序 Nginx 处理每一个用户请求时,都是按照若干个不同阶段(phase)依次处理的,而不是根据配置文件上的顺序. Nginx 处理请求的过程一共划分为 11 个阶段,按照执行顺序依次是 ...
- [IOI2007]Miners
[IOI2007]Miners 题目大意: 两个人吃东西,总共有\(3\)种食物,每个人每次吃到食物时可以获得的收益是当前食物和前两次吃的食物中,不同食物的种数.现在给定一个长度为\(n(n\le10 ...