PTA第6、7、8次作业的总结

  1. 前言
    这三次pta作业主要考查了电信计费系列的问题,从一开始的座机计费,再到座机计费与手机计费结合,最后到短信计费。其中座机计费与手机计费是难度最大的一次题目,因为它综合考虑的因素最多,需要花一定的时间才能解决,而且这题与座机计费的那题联系紧密,环环相扣。至于其它的题目,像C~K的班级,按照题目修改程序,商品内部类购物券,动物发声模拟器这几道题目都不是难度非常大的题目,只要我们认真审题,同时掌握上课老师讲的内容,基本上可以解决。详情见下面的设计与分析。
  2. 设计与分析

  3. 7-1 电信计费系列1-座机计费

实现一个简单的电信计费程序:
假设南昌市电信分公司针对市内座机用户采用的计费方式:
月租20元,接电话免费,市内拨打电话0.1元/分钟,省内长途0.3元/分钟,国内长途拨打0.6元/分钟。不足一分钟按一分钟计。
南昌市的区号:0791,江西省内各地市区号包括:0790~0799以及0701。

输入格式:
输入信息包括两种类型
1、逐行输入南昌市用户开户的信息,每行一个用户,
格式:u-号码 计费类型 (计费类型包括:0-座机 1-手机实时计费 2-手机A套餐)
例如:u-079186300001 0
座机号码除区号外由是7-8位数字组成。
本题只考虑计费类型0-座机计费,电信系列2、3题会逐步增加计费类型。
2、逐行输入本月某些用户的通讯信息,通讯信息格式:
座机呼叫座机:t-主叫号码 接听号码 起始时间 结束时间
t-079186330022 058686330022 2022.1.3 10:00:25 2022.1.3 10:05:11
以上四项内容之间以一个英文空格分隔,
时间必须符合”yyyy.MM.dd HH:mm:ss”格式。提示:使用SimpleDateFormat类。
以上两类信息,先输入所有开户信息,再输入所有通讯信息,最后一行以”end”结束。
注意:
本题非法输入只做格式非法的判断,不做内容是否合理的判断(时间除外,否则无法计算),比如:
1、输入的所有通讯信息均认为是同一个月的通讯信息,不做日期是否在同一个月还是多个月的判定,直接将通讯费用累加,因此月租只计算一次。
2、记录中如果同一电话号码的多条通话记录时间出现重合,这种情况也不做判断,直接 计算每条记录的费用并累加。
3、用户区号不为南昌市的区号也作为正常用户处理。

输出格式:
根据输入的详细通讯信息,计算所有已开户的用户的当月费用(精确到小数点后2位,
单位元)。假设每个用户初始余额是100元。
每条通讯信息单独计费后累加,不是将所有时间累计后统一计费。
格式:号码+英文空格符+总的话费+英文空格符+余额
每个用户一行,用户之间按号码字符从小到大排序。

错误处理:
输入数据中出现的不符合格式要求的行一律忽略。

建议类图:
参见图1、2、3,可根据理解自行调整:

PTA第6、7、8次作业的总结
                                图1

图1中User是用户类,包括属性:
userRecords (用户记录)、balance(余额)、chargeMode(计费方式)、number(号码)。

ChargeMode是计费方式的抽象类:
chargeRules是计费方式所包含的各种计费规则的集合,ChargeRule类的定义见图3。
getMonthlyRent()方法用于返回月租(monthlyRent)。

UserRecords是用户记录类,保存用户各种通话、短信的记录,
各种计费规则将使用其中的部分或者全部记录。
其属性从上到下依次是:
市内拨打电话、省内(不含市内)拨打电话、省外拨打电话、
市内接听电话、省内(不含市内)接听电话、省外接听电话的记录
以及发送短信、接收短信的记录。

PTA第6、7、8次作业的总结
                                 图2

图2中CommunicationRecord是抽象的通讯记录类:
包含callingNumber拨打号码、answerNumber接听号码两个属性。
CallRecord(通话记录)、MessageRecord(短信记录)是它的子类。

CallRecord(通话记录类)包含属性:
通话的起始、结束时间以及
拨号地点的区号(callingAddressAreaCode)、接听地点的区号(answerAddressAreaCode)。
区号用于记录在哪个地点拨打和接听的电话。座机无法移动,就是本机区号,如果是手机号,则会有差异。

PTA第6、7、8次作业的总结
                                    图3

图3是计费规则的相关类,这些类的核心方法是:
calCost(ArrayList callRecords)。
该方法针根据输入参数callRecords中的所有记录计算某用户的某一项费用;如市话费。
输入参数callRecords的约束条件:必须是某一个用户的符合计费规则要求的所有记录。

LandPhoneInCityRule、LandPhoneInProvinceRule、LandPhoneInLandRule三个类分别是
座机拨打市内、省内、省外电话的计费规则类,用于实现这三种情况的费用计算。
(提示:可以从UserRecords类中获取各种类型的callRecords)。
后续扩展说明:
后续题目集将增加手机用户,手机用户的计费方式中除了与座机计费类似的主叫通话费之外,还包含市外接听电话的漫游费以及发短信的费用。在本题的设计时可统一考虑。
通话记录中,手机需要额外记录拨打/接听的地点的区号,比如:
座机打手机:t-主叫号码 接听号码 接听地点区号 起始时间 结束时间
t-079186330022 13305862264 020 2022.1.3 10:00:25 2022.1.3 10:05:11
手机互打:t-主叫号码 拨号地点 接听号码 接听地点区号 起始时间 结束时间
t-18907910010 0791 13305862264 0371 2022.1.3 10:00:25 2022.1.3 10:05:11
短信的格式:m-主叫号码,接收号码,短信内容
m-18907910010 13305862264 welcome to jiangxi
m-13305862264 18907910010 thank you

输入样例:
在这里给出一组输入。例如:

u-079186300001 0
t-079186300001 058686330022 2022.1.3 10:00:25 2022.1.3 10:05:25
end
输出样例:
在这里给出相应的输出。例如:

079186300001 3.0 77.0
其余参考样例详见附件,未尽事宜以附件样例为准:

代码长度限制
40 KB
时间限制
400 ms
内存限制
64 MB

本题的难度较大,一开始会完全不知道该如何动手,关键代码如下:

点击查看代码

public static boolean judgeRegister(String str){
        boolean flag2 = str.matches("u-0791[0-9]{7,8} 0");
        if(flag2){
            return true;
        }
        else
            return false;
    }
    public static boolean judgeProcess(String str){
        boolean flag2 = str.matches("t-0791[0-9]{7,8} [0-9]{11,12} [0-9]{4}.[0-9]{1,2}.[0-9]{1,2} [0-9]{1,2}:[0-9]{1,2}:[0-9]{1,2} [0-9]{4}.[0-9]{1,2}.[0-9]{1,2} [0-9]{1,2}:[0-9]{1,2}:[0-9]{1,2}");

        if(flag2){
            return true;
        }
        else
            return false;
    }
  • 7-1 电信计费系列2-手机+座机计费

实现南昌市电信分公司的计费程序,假设该公司针对手机和座机用户分别采取了两种计费方案,分别如下:
1、针对市内座机用户采用的计费方式(与电信计费系列1内容相同):
月租20元,接电话免费,市内拨打电话0.1元/分钟,省内长途0.3元/分钟,国内长途拨打0.6元/分钟。不足一分钟按一分钟计。
假设本市的区号:0791,江西省内各地市区号包括:0790~0799以及0701。
2、针对手机用户采用实时计费方式:
月租15元,市内省内接电话均免费,市内拨打市内电话0.1元/分钟,市内拨打省内电话0.2元/分钟,市内拨打省外电话0.3元/分钟,省内漫游打电话0.3元/分钟,省外漫游接听0.3元/分钟,省外漫游拨打0.6元/分钟;
注:被叫电话属于市内、省内还是国内由被叫电话的接听地点区号决定,比如以下案例中,南昌市手机用户13307912264在区号为020的广州接听了电话,主叫号码应被计算为拨打了一个省外长途,同时,手机用户13307912264也要被计算省外接听漫游费:
u-13307912264 1
t-079186330022 13307912264 020 2022.1.3 10:00:25 2022.1.3 10:05:11

输入:
输入信息包括两种类型
1、逐行输入南昌市用户开户的信息,每行一个用户,含手机和座机用户
格式:u-号码 计费类型 (计费类型包括:0-座机 1-手机实时计费 2-手机A套餐)
例如:u-079186300001 0
座机号码由区号和电话号码拼接而成,电话号码包含7-8位数字,区号最高位是0。
手机号码由11位数字构成,最高位是1。
本题在电信计费系列1基础上增加类型1-手机实时计费。
手机设置0或者座机设置成1,此种错误可不做判断。
2、逐行输入本月某些用户的通讯信息,通讯信息格式:
座机呼叫座机:t-主叫号码 接听号码 起始时间 结束时间
t-079186330022 058686330022 2022.1.3 10:00:25 2022.1.3 10:05:11
以上四项内容之间以一个英文空格分隔,
时间必须符合”yyyy.MM.dd HH:mm:ss”格式。提示:使用SimpleDateFormat类。
输入格式增加手机接打电话以及收发短信的格式,手机接打电话的信息除了号码之外需要额外记录拨打/接听的地点的区号,比如:
座机打手机:
t-主叫号码 接听号码 接听地点区号 起始时间 结束时间
t-079186330022 13305862264 020 2022.1.3 10:00:25 2022.1.3 10:05:11
手机互打:
t-主叫号码 拨号地点 接听号码 接听地点区号 起始时间 结束时间
t-18907910010 0791 13305862264 0371 2022.1.3 10:00:25 2022.1.3 10:05:11

注意:以上两类信息,先输入所有开户信息,再输入所有通讯信息,最后一行以”end”结束。

输出:
根据输入的详细通讯信息,计算所有已开户的用户的当月费用(精确到小数点后2位,单位元)。假设每个用户初始余额是100元。
每条通讯、短信信息均单独计费后累加,不是将所有信息累计后统一计费。
格式:号码+英文空格符+总的话费+英文空格符+余额
每个用户一行,用户之间按号码字符从小到大排序。
错误处理:
输入数据中出现的不符合格式要求的行一律忽略。

本题只做格式的错误判断,无需做内容上不合理的判断,比如同一个电话两条通讯记录的时间有重合、开户号码非南昌市的号码等,此类情况都当成正确的输入计算。但时间的输入必须符合要求,比如不能输入2022.13.61 28:72:65。
建议类图:
参见图1、2、3:

PTA第6、7、8次作业的总结

图1

图1中User是用户类,包括属性:
userRecords (用户记录)、balance(余额)、chargeMode(计费方式)、number(号码)。
ChargeMode是计费方式的抽象类:
chargeRules是计费方式所包含的各种计费规则的集合,ChargeRule类的定义见图3。
getMonthlyRent()方法用于返回月租(monthlyRent)。
UserRecords是用户记录类,保存用户各种通话、短信的记录,
各种计费规则将使用其中的部分或者全部记录。
其属性从上到下依次是:
市内拨打电话、省内(不含市内)拨打电话、省外拨打电话、
市内接听电话、省内(不含市内)接听电话、省外接听电话的记录
以及发送短信、接收短信的记录。

PTA第6、7、8次作业的总结

图2

图2中CommunicationRecord是抽象的通讯记录类:
包含callingNumber拨打号码、answerNumber接听号码两个属性。
CallRecord(通话记录)、MessageRecord(短信记录)是它的子类。CallRecord(通话记录类)包含属性:
通话的起始、结束时间以及
拨号地点的区号(callingAddressAreaCode)、接听地点的区号(answerAddressAreaCode)。
区号用于记录在哪个地点拨打和接听的电话。座机无法移动,就是本机区号,如果是手机号,则会有差异。

PTA第6、7、8次作业的总结

图3

图3是计费规则的相关类,这些类的核心方法是:
calCost(ArrayList callRecords)。
该方法针根据输入参数callRecords中的所有记录计算某用户的某一项费用;如市话费。
输入参数callRecords的约束条件:必须是某一个用户的符合计费规则要求的所有记录。
SendMessageRule是发送短信的计费规则类,用于计算发送短信的费用。
LandPhoneInCityRule、LandPhoneInProvinceRule、LandPhoneInLandRule三个类分别是座机拨打市内、省内、省外电话的计费规则类,用于实现这三种情况的费用计算。
(提示:可以从UserRecords类中获取各种类型的callRecords)。
注意:以上图中所定义的类不是限定要求,根据实际需要自行补充或修改。

输入样例:
在这里给出一组输入。例如:

u-13811111111 1
t-13811111111 0791 13811111110 020 2022.1.3 08:00:00 2022.1.3 08:09:20
end
输出样例:
在这里给出相应的输出。例如:

13811111111 3.0 82.0
更多内容详见附件:

代码长度限制
40 KB
时间限制
400 ms
内存限制
64 MB

本次作业是上一题作业的难度升级版,需要我们更加仔细认真地去做。部分代码如下:

点击查看代码

    public static int Area(String s1,String[] s) {
        int a = 0;
        int b= Integer.parseInt(s1.substring(1, 4));//获取区号后三位
        int c= Integer.parseInt(s[1].substring(1, 4));//获取区号后三位
        if((b>=790&&b<=799||b==701)&&(c>=790&&c<=799||c==701)) { if(b="=791&&c==791)" a="1;//&#x5E02;&#x5185;" } else return a; 根据号码找到对应的用户 public static int getuser(string str) n="0;" for(int i="0;i<m;i++)" if(str.equals(user[i].number)) n; 计算通话时长 getcallduration(string s1,string s2) string a[]="s1.split(":");" b[]="s2.split(":");" sum="0;" hour="0;" minute="0;" miao="0;" - integer.parseint(a[1]); if(integer.parseint(b[2]) integer.parseint(a[2])>0) {
            miao = 1;
        }
        else
            miao = 0;
        sum = 60*hour+minute+miao;
        return sum;
    }
</=799||c==701))></=799||b==701)&&(c>

有个需要注意的问题是:写在静态类里面的方法也应该是静态的。 * 7-2 sdut-Collection-sort–C~K的班级(II) 分数 10 作者 周雪芹 单位 山东理工大学 经过不懈的努力,C~K终于当上了班主任。

现在他要统计班里学生的名单,但是C~K在教务系统中导出班级名单时出了问题,发现会有同学的信息重复,现在他想把重复的同学信息删掉,只保留一个,
但是工作量太大了,所以找到了会编程的你,你能帮他解决这个问题吗?

输入格式:
第一行输入一个N,代表C~K导出的名单共有N行(N

Original: https://www.cnblogs.com/zsl-236236/p/16356327.html
Author: L2B3J
Title: PTA第6、7、8次作业的总结

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/569241/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

  • Dart 初探 (一)

    前言 Dart 是 Google 为 Flutter 开发的一款用于 网页编程的语言,其类似于 Javascript,也是一种面向对象的语言,但其采用 基于类的编程,语法风格接近C…

    Java 2023年6月7日
    096
  • 双指针问题的算法

    双指针主要分两类: 快慢指针和左右指针 对于 链表问题, 我们一般可以使用 快慢指针解决所谓的快慢指针是指, 使用两个指针按照不同的速度前进, 有两个指针我们可以确定: 一些题目 …

    Java 2023年6月7日
    0153
  • markdown mermaid流程图

    流程图 所有流程图都由节点、几何图像、箭头或线条组成。 mermaid代码定义了这些节点和边的制作和交互方式。可以有不同的箭头类型、多向箭头以及与子图的连接。 flowchart …

    Java 2023年6月5日
    074
  • Kubernetes集群环境搭建全过程

    资源准备以及服务器初始化 所有服务器执行一下脚本进行配置信息初始化: #!/bin/bash cd dirname $0 关闭selinux setenforce 0 sed -i…

    Java 2023年6月5日
    099
  • JAVA中使用JSch库实现SSH功能

    一、简介 JSch库可以实现Java连接Linux服务器并操作命令、文件等,支持常用的各种授权模式。网址:http://www.jcraft.com/jsch/ 类似C#中的SSH…

    Java 2023年5月29日
    081
  • 【力扣】5. 最长回文子串

    给你一个字符串 s,找到 s 中最长的回文子串。 示例 1:输入:s = “babad”输出:”bab”解释:”aba&…

    Java 2023年6月8日
    0128
  • 干货整理!ERP在制造业的发展趋势如何,看这一篇就够了

    写在前面 制造业ERP是指企业资源计划(ERP)软件和系统,用于计划、管理和交付支持制造商业务的特定功能。ERP系统是一种制造管理软件,它通过管理和改进公司资源的利用方式来提高制造…

    Java 2023年6月5日
    0130
  • IO流(Properties的使用方法)

    Properties:属性集合类。是一个可以和IO流相结合使用的集合类。 Properties 可保存在流中或从流中加载。属性列表中每个键及其对应值都是一个字符串。 /* 特殊功能…

    Java 2023年6月5日
    095
  • 软考总结

    软考全称是计算机技术与软件专业技术资格考试,学生可以为毕业后面试锦上添花,已参加工作且不是本专业的拿个证在一定程度上弥补不是本专业的劣势。如果你要往架构师、项目经理等晋升,有些企业…

    Java 2023年6月13日
    079
  • Java后端开发常用工具

    Java后端开发常用工具推荐: 俗话说,工欲善其事,必先利其器。不过初学时候不大建议过度依赖IDE等过多工具,这会让自己的编程基础功变得很差,比如各种语法的不熟悉,各种关键字比如s…

    Java 2023年5月29日
    090
  • 【SpringCloud-Alibaba系列教程】9.Fegin整合sentinel

    我们开始吧 首先我们需要在配置文件中配置Fegin的相关规则 #&#x5F00;&#x542F;fegin&#x5BF9;sentinel&#x65…

    Java 2023年6月5日
    085
  • spring boot 集成 Swagger 接口文档

    1.添加依赖 2.在 Spring Boot 配置文件中添加配置参数 3.创建配置类: Swagger 默认会根据配置的包,扫描所有接口并生成对应的 API 描述和参数信息,但这样…

    Java 2023年5月30日
    063
  • PotPlayer播放百度云盘视频

    需要的工具 PotPlayer、油猴tampermonkey、坚果(这个不用下载,有个账号就行)下载地址:百度网盘 步骤 安装油猴tampermonkey 拖拽 Tampermon…

    Java 2023年6月9日
    0266
  • Java语言基础

    (一)Java编译运行过程 编译期:Java源文件经过编译生成.class字节码文件运行期:JVM加载.class并运行.class特点:跨平台,一次编译到处使用(跨平台特性如下图…

    Java 2023年6月5日
    092
  • 使用JAVA CompletableFuture实现流水线化的并行处理,深度实践总结

    大家好,又见面啦。 在项目开发中,后端服务对外提供 API接口一般都会关注 &#x54CD;&#x5E94;&#x65F6;&#x957F;。但是某…

    Java 2023年6月7日
    085
  • java 继承关系判断

    Class.java # public native boolean isInstance(Object obj); // true System.out.println(chil…

    Java 2023年6月8日
    087
亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球