List<E> 、Set<E>和Map<K,E>的简单应用
题目一:
创建两个线性表,分别存储{“chen”,“wang”,“liu”,“zhang”}和{“chen”,“hu”,“zhang”},求这两个线性表的交集和并集。
代码:
List_Test.java
/**
* 利用List<E>和Set<E>,求交集和并集;
*/
package cn.edu.ccut1;
import java.util.*; public class Test_List { public static void main(String[] args) {
ArrayList<String> L1 = new ArrayList<String>();
ArrayList<String> L2 = new ArrayList<String>();
L1.add("chen");
L1.add("wang");
L1.add("liu");
L1.add("zhang");
L2.add("chen");
L2.add("Hu");
L2.add("zhang");
ArrayList<String> Jj = new ArrayList<String>();
Jj.addAll(L1);
Jj.retainAll(L2); //将Jj中与L2中不相同的元素全部剔除;
System.out.println("交集是:"+Jj.toString());
HashSet<String> Bj = new HashSet<String>();
Bj.addAll(L1);
Bj.addAll(L2); //利用Set<E>唯一性的特点去除重复的元素取得并集;
System.out.println("并集是:"+Bj.toString());
}
}
运行结果:

题目二:
编写一个应用程序,输入一个字符串,该串至少由数字、大写字母和小写字母三种字符中的一种构成,如“123”、“a23”、“56aD”、“DLd”、“wq”、“SSS”、“4NA20”,对输入内容进行分析,统计每一种字符的个数,并将该个数和每种字符分别输出显示。如:输入内容为“34Ah5yWj”,则输出结果为:数字——共3个,分别为3,4,5;小写字母——共3个,分别为h,y,j;大写字母——共2个,分别为A,W。
代码:
Map_Test.java
package cn.edu.ccut2;
import java.util.*; public class Map_Test { public static void main(String[] args) {
System.out.println("请输入一个字符串:");
HashMap<String, String> M = new HashMap<String, String>();
Scanner r = new Scanner(System.in);
String str = r.nextLine();
int length = str.length();
String c;
int count_num = 0; //统计数字,小写字母,大写字母的个数;
int count_A = 0;
int count_a = 0;
for(int i = 0 ; i < length ; i++){
c = str.substring(i, i+1);
if(c.matches("\\d")){//判断是否为数字;
if(M.get("数字")==null){
M.put("数字", c);
}
else{
M.put("数字", M.get("数字")+","+c);
}
count_num++;
}
if(c.matches("[a-z]")){//判断是否为小写字母;
if(M.get("小写字母")==null){
M.put("小写字母", c);
}
else{
M.put("小写字母", M.get("小写字母")+","+c);
}
count_a++;
}
if(c.matches("[A-Z]")){//判断是否为大写字母;
if(M.get("大写字母")==null){
M.put("大写字母", c);
}
else{
M.put("大写字母", M.get("大写字母")+","+c);
}
count_A++;
}
}
Set set = M.entrySet(); //返回包含映射中项的集合;
Iterator it = set.iterator(); //获取迭代对象;
while(it.hasNext()){
Map.Entry me = (Map.Entry)it.next();
System.out.print(me.getKey());
if(me.getKey().equals("数字")){
System.out.print("——共"+count_num+"个,");
}else if(me.getKey().equals("小写字母")){
System.out.print("——共"+count_a+"个,");
}else if(me.getKey().equals("大写字母")){
System.out.print("——共"+count_A+"个,");
}
System.out.println("分别为"+me.getValue());
}
}
}
运行结果:

List<E> 、Set<E>和Map<K,E>的简单应用的更多相关文章
- cocos基础教程(5)数据结构介绍之cocos2d::Map<K,V>
1.概述 cocos2d::Map<K,V> 是一个内部使用了 std::unordered_map的关联容器模版. std::unordered_map 是一个存储了由key-value ...
- 关于jsp利用EL和struts2标签来遍历ValueStack的东东 ------> List<Map<K,V>> 以及 Map<K,<List<xxx>>> 的结构遍历
//第一种结构Map<K,<List<xxx>>> <body> <% //显示map<String,List<Object>& ...
- JDK源码(1.7) -- java.util.Map<K,V>
java.util.Map<K,V> 源码分析 --------------------------------------------------------------------- ...
- Map<k,v>接口
https://docs.oracle.com/javase/8/docs/api/java/util/Map.html public interface Map<K,V> K—key,V ...
- 随笔1 interface Map<K,V>
第一次写笔记就从map开始吧,如上图所示,绿色的是interface,黄色的是abstract class,蓝色的是class,可以看出所有和图相关的接口,抽象类和类的起源都是interface ma ...
- Cocos2d-x之Map<K, V>
| 版权声明:本文为博主原创文章,未经博主允许不得转载. Map<K, V>是Cocos2d-x 3.0x中推出的字典容器,它也能容纳Ref类型.Map<K,V>是模仿C+ ...
- JS Map 和 List 的简单实现代码
javascript中是没有map和list 结构的. 本篇文章是对在JS中Map和List的简单实现代码进行了详细的分析介绍,需要的朋友参考下 代码如下: /* * MAP对象,实现MAP功能 * ...
- 编写函数求整形数组a中存储的m个不重复的整数的第k大的整数(其中m>=1,1<=k<=m)很简单的一个思路是酱紫的:管他辣么多干啥,上来一把排序然后直接得答案
/** * @author:(LiberHome) * @date:Created in 2019/2/28 20:38 * @description: * @version:$ *//*编写函数求整 ...
- Mybatis返回List<Map<K,V>>
最终映射的字段名 会被作为 hashMap 的 key , <!-- TODO 测试返回 HashMap--> <resultMap id="testResultMap&q ...
随机推荐
- 1072 开学寄语 (20分)C语言
下图是上海某校的新学期开学寄语:天将降大任于斯人也,必先删其微博,卸其 QQ,封其电脑,夺其手机,收其 ipad,断其 wifi,使其百无聊赖,然后,净面.理发.整衣,然后思过.读书.锻炼.明智.开悟 ...
- Spring的一些基本概念(面试备用哦)
1.什么是Spring, 它有什么特点? 包括哪些内容? Spring是一个轻量级的控制反转(IoC)和面向切面(AOP)的容器框架. ◆ 轻量——从大小与开销两方面而言Spring都是轻量的.完整 ...
- ASCII、UNICODE、UTF
在计算机中,一个字节对应8位,每位可以用0或1表示,因此一个字节可以表示256种情况. ascii 美国人用了一个字节中的后7位来表达他们常用的字符,最高位一直是0,这便是ascii码. 因此asci ...
- JAVA读取yml配置文件指定key下的所有内容
先引入需要的依赖 <!--读取yml文件--> <dependency> <groupId>org.yaml</groupId> <artifac ...
- 一条SQL注入引出的惊天大案2:无限战争
前情回顾: 经过黑衣人和老周的合作,终于清除了入侵Linux帝国的网页病毒,并修复了漏洞.不曾想激怒了幕后的黑手,一场新的风雨即将来临. 详情参见:一条SQL注入引出的惊天大案 风云再起 小Q是L ...
- Java扫描指定文件路径下的文件并且递归扫描其子目录下的所有文件
本文主要实现了扫描指定文件路径下的文件,递归扫描其子目录下的所有文件信息,示例文件为: 要求将后缀为.dat的文件夹信息也写入到数据库中,然后将.chk文件解析,将文件中对应的内容读出来写入到数据库, ...
- Js 数组按数量分部!
使用 reduce 将数组分为几个部分,每个部分最多10个! 相比其他语言使用 js 实现这个逻辑非常的简单方便! var group = function (source, step) { if ...
- Java 用链表实现栈和队列
栈 是一种基于后进先出(LIFO)策略的集合类型.当邮件在桌上放成一叠时,就能用栈来表示.新邮件会放在最上面,当你要看邮件时,会一封一封从上到下阅读.栈的顶部称为栈顶,所有操作都在栈顶完成. 前面提到 ...
- 关于neo4j初入门(2)
DELETE删除 删除节点及相关节点和关系. DELETE <node-name-list> DELETE <node1-name>,<node2-name>,&l ...
- 投影方式- Unity3D游戏开发培训
投影方式- Unity3D游戏开发培训 作者:Jesai 2018-02-12 20:33:13 摘 要 透视投影是3D渲染的基本概念,也是3D程序设计的基础.掌握透视投影的原理对于深入理解其他 ...