Java复习41(PTA)

ops/2024/11/18 8:58:51/

jmu-Java-m06 根据姓名以及电话号码查找联系人

分数 20

全屏浏览

切换布局

作者 郑如滨

单位 集美大学

该程序包含:

Person类:

属性:int id, String name, String phoneNumber,String address。

方法:

无参构造方法,有参构造方法(id, name, phoneNumber,addres),

各个参数的getter/setter方法,

toString()方法。

Utils类:

用于生成通讯录(具体代码下面已给出)

Main类的main方法:

使用Utils类创建一个通讯录personList,使用Map将personList中的person对象按name分类存储。即,key为person的name值,value为对应的person对象的List列表(说明:就是将相同name值的person对象放在一起List列表中)。

接下来就可以在该Map中根据姓名与电话号码查询联系人。查询方法如下:

  1. 输入n
  2. 输入n行的name以及phoneNumber值,以空格分开。然后根据name查找map,如果找到且在列表中的存在某个person对象的电话号码也相同,则输该person对象。如果找不到(即找不到name与电话号码均匹配的Person对象)则输出提示信息。
  3. 最后一行输出map的数量,即map.size()(该行输出在输出样例中未显示)

Utils类实现如下:

class Utils{private static final Random rd = new Random(3);private static final int number = 200000;private static List<String> getPersonName(){StringBuilder sb = new StringBuilder();List<String> names = new ArrayList<String>();for(int i=0;i<Utils.number;i++) {sb.delete(0, sb.length());for(int j=0;j<4;j++) {if(j==0) {sb.append((char)('A'+rd.nextInt(26)));}else {sb.append((char)('a'+rd.nextInt(26)));}}names.add(sb.toString());}return names;}private static List<String> getPhoneNumber(){String[] telFirst="134,135,136,137,138,139,150,151,152,157,158,159,130,131,132,155,156,133,153".split(",");StringBuilder sb = new StringBuilder();List<String> phoneNumbers = new ArrayList<String>();for(int i=0;i<Utils.number;i++) {sb.delete(0, sb.length());for(int j=0;j<9;j++) {if(j==0) {sb.append(telFirst[rd.nextInt(telFirst.length)]);}else {sb.append(rd.nextInt(10));}}phoneNumbers.add(sb.toString());}return phoneNumbers;}private static List<String> getPersonAddress(){List<String> addresses = new ArrayList<String>();String[] roads = {"HuanDao Road","WenZeng Road","ZhongShang Road","KaiHe Road","NanHua Road","SongBai Road","BinShui Road","ShiGu Road","JiYuan Road","YinJiang Road"};StringBuilder sb = new StringBuilder();for(int i=0;i<Utils.number;i++) {sb.delete(0, sb.length());for(int j=0;j<2;j++) {if(j==1) {sb.append(roads[rd.nextInt(roads.length)]);}else {sb.append("Room "+rd.nextInt(100)+"-"+rd.nextInt(1000)+"-"+rd.nextInt(10000)+", ");}}addresses.add(sb.toString());}return addresses;}public static List<Person> getPersonList(){List<String> names = Utils.getPersonName();List<String> phones = Utils.getPhoneNumber();List<String> addresses = Utils.getPersonAddress();List<Person> persons = new ArrayList<Person>();for(int i=0;i<Utils.number;i++) {Person person = new Person();person.setId(i);person.setName(names.get(i));person.setPhoneNumber(phones.get(i));person.setAddress(addresses.get(i));persons.add(person);}return persons;}
}

输入格式:

一个正整数n

接下去的n行:

输入name以及phoneNumber

输出格式:

如果找到对象则输出该对象

未找到对象则输出"Not found!"。

输入样例:

5
Vern 15678785276
Paul 13369862612
Todd 15094198414
Mike 15079239680
Tony 13739215033

输出样例:

Not found!
Person [id=162538, name=Paul, phoneNumber=13369862612, address=Room 8-446-6866, ShiGu Road]
Person [id=139814, name=Todd, phoneNumber=15094198414, address=Room 8-856-5546, JiYuan Road]
Not found!
Person [id=184950, name=Tony, phoneNumber=13739215033, address=Room 71-896-9345, SongBai Road]
161999

代码长度限制

50 KB

时间限制

2500 ms

内存限制

256 MB

栈限制

8192 KB

java">import java.util.*;public class Main {public static void main(String[] args) {List<Person> personList = Utils.getPersonList();Map<String, List<Person>> personMap = new HashMap<>();// 按姓名分类存储for (Person person : personList) {personMap.computeIfAbsent(person.getName(), k -> new ArrayList<>()).add(person);}Scanner scanner = new Scanner(System.in);int n = scanner.nextInt();scanner.nextLine(); // 读取换行符for (int i = 0; i < n; i++) {String line = scanner.nextLine();String[] parts = line.split(" ");String name = parts[0];String phoneNumber = parts[1];if (personMap.containsKey(name)) {List<Person> persons = personMap.get(name);boolean found = false;for (Person person : persons) {if (person.getPhoneNumber().equals(phoneNumber)) {System.out.println(person);found = true;break;}}if (!found) {System.out.println("Not found!");}} else {System.out.println("Not found!");}}System.out.println(personMap.size()); // 输出map的数量scanner.close();}
}class Person {private int id;private String name;private String phoneNumber;private String address;public Person() {}public Person(int id, String name, String phoneNumber, String address) {this.id = id;this.name = name;this.phoneNumber = phoneNumber;this.address = address;}public int getId() {return id;}public void setId(int id) {this.id = id;}public String getName() {return name;}public void setName(String name) {this.name = name;}public String getPhoneNumber() {return phoneNumber;}public void setPhoneNumber(String phoneNumber) {this.phoneNumber = phoneNumber;}public String getAddress() {return address;}public void setAddress(String address) {this.address = address;}@Overridepublic String toString() {return "Person [id=" + id + ", name=" + name + ", phoneNumber=" + phoneNumber + ", address=" + address + "]";}
}class Utils {private static final Random rd = new Random(3);private static final int number = 200000;private static List<String> getPersonName() {StringBuilder sb = new StringBuilder();List<String> names = new ArrayList<String>();for (int i = 0; i < Utils.number; i++) {sb.delete(0, sb.length());for (int j = 0; j < 4; j++) {if (j == 0) {sb.append((char) ('A' + rd.nextInt(26)));} else {sb.append((char) ('a' + rd.nextInt(26)));}}names.add(sb.toString());}return names;}private static List<String> getPhoneNumber() {String[] telFirst = "134,135,136,137,138,139,150,151,152,157,158,159,130,131,132,155,156,133,153".split(",");StringBuilder sb = new StringBuilder();List<String> phoneNumbers = new ArrayList<String>();for (int i = 0; i < Utils.number; i++) {sb.delete(0, sb.length());for (int j = 0; j < 9; j++) {if (j == 0) {sb.append(telFirst[rd.nextInt(telFirst.length)]);} else {sb.append(rd.nextInt(10));}}phoneNumbers.add(sb.toString());}return phoneNumbers;}private static List<String> getPersonAddress() {List<String> addresses = new ArrayList<String>();String[] roads = {"HuanDao Road", "WenZeng Road", "ZhongShang Road", "KaiHe Road", "NanHua Road", "SongBai Road", "BinShui Road", "ShiGu Road", "JiYuan Road", "YinJiang Road"};StringBuilder sb = new StringBuilder();for (int i = 0; i < Utils.number; i++) {sb.delete(0, sb.length());for (int j = 0; j < 2; j++) {if (j == 1) {sb.append(roads[rd.nextInt(roads.length)]);} else {sb.append("Room " + rd.nextInt(100) + "-" + rd.nextInt(1000) + "-" + rd.nextInt(10000) + ", ");}}addresses.add(sb.toString());}return addresses;}public static List<Person> getPersonList() {List<String> names = Utils.getPersonName();List<String> phones = Utils.getPhoneNumber();List<String> addresses = Utils.getPersonAddress();List<Person> persons = new ArrayList<Person>();for (int i = 0; i < Utils.number; i++) {Person person = new Person();person.setId(i);person.setName(names.get(i));person.setPhoneNumber(phones.get(i));person.setAddress(addresses.get(i));persons.add(person);}return persons;}
}


http://www.ppmy.cn/ops/134664.html

相关文章

基于Hadoop、hive的数仓搭建实践

文章目录 架构图Hadoop搭建Hive 搭建MySQL搭建官网文档下载配置配置hive环境变量配置日志文件配置hive-site 复制mysql 驱动包删除日志包初始化元数据启动metastore服务使用hive CLI启动hiveServer2访问hiveserver2客户端连接beeline shell连接 Dbeaver连接经验 基于HDFS Hive…

前端三大组件之CSS,三大选择器,游戏网页仿写

回顾 full stack全栈 Web前端三大组件 结构(html) 样式(css) 动作/交互(js) --- 》 框架vue&#xff0c;安哥拉 div 常用的标签 扩展标签 列表 ul/ol order——有序号 unordered——没序号的黑点 <!DOCTYPE html> <html><head><meta charset"…

web前端开发网页--css样式的使用

1、css层叠性 <!DOCTYPE html> <html><head><meta charset"UTF-8"><title>css层叠性</title><style type"text/css">p{font-size: 12px;font-family: "微软雅黑";}.special{font-size: 24px;}#one{c…

基于java+ssm+Vue的校园美食交流系统设计与实现

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; Springboot mybatis Maven mysql5.7或8.0等等组成&#x…

02_Spring_IoC实现

接下来先简单说一下关于IoC的一些要点,后面我们再详细一步一步讨论。 一、IoC控制反转 IoC控制反转它是一种思想,不是具体的实现控制反转的目的是为了降低程序的耦合度,提高程序的可扩展性,从而满足OCP原则和DIP原则控制反转,那到底反转是什么东西? 我们不再使用某个对象…

管家婆财贸ERP BR006.收款销售提成报表

最低适用版本: 财贸系列 20.8 插件简要功能说明: 收款单选销售单结算后自动计算职员提成更多细节描述见下方详细文档插件操作视频: 进销存类定制插件--收款销售提成报表 插件详细功能文档: 1. 应用中心菜单增加报表【收款销售提成报表】 a. b. 查询条件: ⅰ. 日期区间…

go channel中的 close注意事项 range取数据

在使用 Go 语言中的 close 函数时&#xff0c;有一些注意事项需要牢记&#xff0c;以确保程序的健壮性和正确性&#xff1a; 1. **仅用于通道&#xff08;channel&#xff09;**&#xff1a; - close 函数只能用于关闭通道&#xff0c;不能用于关闭文件、网络连接或其他资源…

【机器学习】数学知识:标准差,方差,协方差,平均数,中位数,众数

标准差、方差和协方差是统计学中重要的概念&#xff0c;用于描述数据的分散程度和变量之间的关系。以下是它们的定义和公式&#xff1a; 1. 标准差 (Standard Deviation) 标准差是方差的平方根&#xff0c;表示数据的分散程度&#xff0c;以与数据相同的单位表示。 公式&…