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 ...
随机推荐
- 关于MySQL幻读的实验
该实验基于 CentOS 7 + MySQL 5.7 进行 打开两个窗口连接到MySQL 第一个连接的事务我们命名为 T1 第二个连接的事务我们命名为 T2 T2 发生在 T1 的 O1 操作结束以 ...
- realme X2谷歌套件
目前市面上的很多手机是不支持谷歌相关组件的,经过不断的测试成功适配realme X2(真机测试完美适配) 为框架的GMS是用户想要体验整套Google服务不可绕开的一环,Google地图.Play商店 ...
- Java 发展简史:初生遇低谷,崛起于互联网
Java 起源与诞生 20世纪90年代,单片式计算机系统诞生,单片式计算机系统不仅廉价,而且功能强大,使用它可以大幅度提升消费性电子产品的智能化程度. SUN公司为了抢占市场先机,在1991年成立了一 ...
- Netty--【详解】
Netty概述:1.netty是基于Java NIO的网络应用框架,client-server框架2.Netty是一个高性能.异步事件驱动的NIO框架,它提供了对TCP.UDP和文件传输的支持,作为一 ...
- Netty快速入门(01)Linux I/O模型介绍
Netty简述 Netty是一个高性能的网络编程框架. 上面提到了几个关键的字眼,高性能,网络编程,框架.这些概括Netty的本质. Netty是一个NIO客户端服务器框架,可以快速轻松地开发协议服务 ...
- 使用WebUploader上传HTML文件并读取文件
需求: 前端需要上传HTML文件并识别里面有多少个特殊标签并录入到数据库. 思路: 使用WebUploader上传文件,然后使用FileReader接口和DOMParser识别HTML中的特殊标签 资 ...
- 搞定SpringBoot多数据源(1):多套源策略
目录 1. 引言 2. 运行环境 3. 多套数据源 3.1 搭建 Spring Boot 工程 3.1.1 初始化 Spring Boot 工程 3.1.2 添加 MyBatis Plus 依赖 3. ...
- BFC 是什么东西?
以下是本人理解的 BFC 和 官方文档BFC资料 . BFC 是页面元素的隐藏属性,全称 : Block Formatting Context 作用: 可以清除子元素浮动后不良效果在线效果地址:ht ...
- python 枚举类型
在python中枚举是一种类(Enum,IntEnum),存放在enum模块中.枚举类型可以给一组标签赋予一组特定的值. 枚举的特点: 枚举类中不能存在相同的标签名 枚举是可迭代的 不同的枚举标签可以 ...
- 让VS2019支持.NET Core WinForms和WPF设计器的临时办法(转)
.net core 3.0 Preview 6,vs2019 16.1.4 暂时还不支持Winform designer 解决方案: 将Form1修改为其他名字 WinForm 编辑项目文件 加 ...