java选做实验4常用集合类使用
admin
2024-01-30 07:49:20
0

(1). 编写Java应用程序,根据用户输入的5个时间(每行一个时间),计算相邻两个时间之间的间隔,共4个结果。注:用户输入的时间格式为“××××年××月××日××时××分××秒”,输出的时间格式为“××日××时××分××秒”。在报告中附上程序截图、完整的运行结果截图和简要文字说明。

该题计算时间和输出时间时,主要用到Date类和日期格式化类SimpleDateFormat。输入时按中文字符串输入,所以处理时也要用到Scanner字符串解析器

源代码如下:

main类中输入字符串处理部分:

主要就是用times来接收输入的时间,date来存储格式化后的日期,将每个日期按字符串输入后用useDelimiter来分割字符串中的数字。最后对times进行格式化作为最后结果输出。

随后抛出异常方法来对赋值,最后在自定义的countTimeDifferent方法里对时间以及时间差进行输出:

countTimeDifferent方法:主要是对传进来的两个时间做比较之后,得到时间差(单位是毫秒)的绝对值通过手动计算年月日时分秒

(其实本来是将long 类型的different作为参数定义了一个Date对象,然后用Date里面的getYear进行输出,但是结果有误改不对就这样了)

package first;
import java.text.ParseException;
import java.util.Date;
import java.text.SimpleDateFormat;
import java.util.*;
public class first {static void countTimeDifferent(Date[]date, int num, String []times){long []time=new long [num];for(int i=0;itime[i+1]){System.out.print(times[i]+"到"+times[i+1]+"的时间间隔是:");}else{System.out.print(times[i+1]+"到"+times[i]+"的时间间隔是:");}long different=Math.abs(time[i]-time[i+1]);different/=1000;//将时间差化为秒数long year,month,day,hour,minute,second;year=different/(60*60*24*365);//得到相差的年数different-=year*(60*60*24*365);month=different/(60*60*24*30);//得到相差的月数different-=month*(60*60*24*30);day=different/(60*60*24);//得到相差的天数different-=day*(60*60*24);hour=different/(60*60);//得到相差的小时数different-=hour*(60*60);minute=different/60;//得到相差的分钟数different-=minute*60;second=different;//秒数System.out.print(year+"年"+month+"月"+day+"日");System.out.println(hour+"时"+minute+"分"+second+"秒");}}public static void main(String []args){System.out.print("请输入要计算的时间差个数:");Scanner scanner=new Scanner(System.in);int num=scanner.nextInt();Date []date=new Date[num];//date用来存储日期String []times=new String[num];//times用来存储以string接收的日期for(int i=0;i

最后就是为了验证我的程序,我测试了7个时间两两各差1个单位的时间(而不是5个)

7
2022年11月18日12分12时23秒
2023年11月18日12分12时23秒
2023年12月18日12分12时23秒
2023年12月19日12分12时23秒
2023年12月19日11分12时23秒
2023年12月19日11分13时23秒
2023年12月19日11分13时24秒

(2). 编写Java应用程序,实现稀疏矩阵的加法和乘法运算,其中稀疏矩阵是指矩阵中的大部分元素的值为0。用户在命令行输入矩阵时矩阵的大小可能有错,因此需要使用异常处理。在报告中附上程序截图、完整的运行结果截图和简要文字说明。

首先我想到的是直接写了一个Matrix类来对矩阵进行定义,其中Matrix里面的分别有:

成员变量:行row、列column、矩阵元素数组matrix[][]:

    private int column;//列数private int row;//行数private int [][]matrix;//矩阵数组

无参构造以及行和列为参数有参构造(矩阵在这步首先是初始化没有具体赋值):

    public Matrix(){column=0;row=0;}public Matrix(int r,int c) {row = r;column = c;matrix = new int[row][column];}

对矩阵元素具体赋值的setMatrix方法:

一开始是用C++里面两个for循环逐一赋值的,但是后来突然想起java可以直接一句完事,所以这里有点单调qaq

    public void setMatrix(int [][]m){matrix=m;}

矩阵输出方法(方便后面四次输出:矩阵1、矩阵2、它们的和以及乘积):

    public void print(){for(int i=0;i

矩阵相加方法:

在相加的方法的参数里面我传进去了一个Matrix类 matrix1作为相加的矩阵,方法内部首先判断两矩阵能否相加(默认类的matrix和传进来的matrix1的矩阵都是合法的),另外在方法内部我重新定义了一个Matrix类matrix2用来接收两矩阵相加的和,对matrix2赋值后就输出提示信息并且调用matrix2的print方法来输出相加后得到的新矩阵。

    public void add(Matrix matrix1){if(column!=matrix1.column||row!=matrix1.row){System.out.println("两矩阵不符合相加条件(行列数均相等),无法相加qwq");}else{Matrix matrix2=new Matrix(column,row);for(int i=0;i

矩阵相乘方法:

2和相加的方法类似,在相乘的方法的参数里面我传进去了一个Matrix类 matrix1作为相加的矩阵,方法内部首先判断两矩阵能否相乘(同样默认类的matrix和传进来的matrix1的矩阵都是合法的),另外在方法内部重新定义了一个Matrix类matrix2用来接收两矩阵相乘的积,对matrix2赋值后就输出提示信息并且调用matrix2的print方法来输出相加后得到的新矩阵。

    public void multiply(Matrix matrix1){if(column!=matrix1.row){//首先判断矩阵是否满足相乘的条件System.out.println("两矩阵不符合相乘条件(左矩阵的列数与右矩阵的行数的相等),无法相乘qwq");}else{Matrix matrix2=new Matrix(row,matrix1.column);for(int i=0;i

2、main里面:

      要对两个矩阵进行初始化这步不难只是对矩阵进异常处理一开始有点不知所措,最后我想到的还是对输入的矩阵进行输入规范化来做的(矩阵元素当做一行来输入)。

        随后输出输入提示信息,并且输入第一个矩阵的行列:

            int column1,column2,row1,row2;Scanner scanner=new Scanner(System.in);System.out.print("请分别输入第一个矩阵的行数和列数");row1=scanner.nextInt();column1=scanner.nextInt();

    然后我定义了一个string来接收矩阵(我的想法是将矩阵作为一行用Scanner的nextLine方法输入),注意nextLine会把之前输入的换行符输入,所以我先让s=scanner的nextLine来去掉上一行的换行符,然后在输出输入提示信息之后再读入有矩阵元素的一行,然后定义一个Scanner类实例input(s为参数),随后以数字外的字符作为分隔符。

            String s=scanner.nextLine();//“吃掉”末尾的换行符System.out.println("请输入第一个矩阵");s=scanner.nextLine();Scanner input=new Scanner(s);input.useDelimiter("[^1234567890]+");//数字外都是分隔符int [][]matrix=new int[row1][column1];//数组初始化

对matrix初始化大小后利用异常处理对matrix赋值,如图的try里面的语句,如果矩阵输入有异常(越界),那么catch里面的语句就会执行输出错误信息并且退出程序,无误后初始化矩阵matrix1

            try{for(int i=0;i

matrix2的初始化与matrix类似

          System.out.print("请分别输入第二个矩阵的行数和列数");row2=scanner.nextInt();column2=scanner.nextInt();s=scanner.nextLine();//“吃掉”末尾的换行符System.out.println("请输入第二个矩阵");s=scanner.nextLine();input=new Scanner(s);input.useDelimiter("[^1234567890]+");//数字外都是分隔符matrix=new int[row2][column2];try{for(int i=0;i

最后是输出

            Matrix matrix2=new Matrix(row2,column2);matrix2.setMatrix(matrix);System.out.println("矩阵1如下:");matrix1.print();System.out.println("矩阵2如下:");matrix2.print();System.out.println("两矩阵相加与相乘的结果分别如下:");matrix1.add(matrix2);matrix1.multiply(matrix2);

测试数据:

3 2
1 2 3 4 5 6
2 3
1 2 3 4 5 63 3
1 2 3 4 5 6
3 3
1 2 3 4 5 63 2
1 2 3 4  5 6 
2 3
1 2 3 4 5 63 3
1 2 3 4 5 6 7 8 9
3 3
1 2 3 4 5 6 7 8 9

应该的没太大问题了吧(大概)

相关内容

热门资讯

bbugreport.exe:... 哎呀,说到这个bbugreport.exe,我的心情真是五味杂陈啊!你懂的,就是那个时不时蹦出来,让...
双网叠加路由器:让网络速度如火... 哎呀,说到这个双网叠加路由器,我简直要跳起来了!你知道吗,自从我换了这款路由器,家里的网络速度简直像...
枭雄怎么重新开始-从失败到新生... 在江湖的沧桑岁月中,每一个枭雄都有过辉煌的巅峰,也有过跌入谷底的苦涩。曾经的我,手握重兵,叱咤风云,...
邮件炸弹攻击主要是什么-警惕!... 邮件炸弹攻击,听起来就像是从科幻电影里跳出来的东西,对吧?但它可是真实存在的,而且就在我们的电子邮箱...
ubuntu 1404关闭3d... 哎呀,说到这个Ubuntu14.04啊,我真的是有点头疼。尤其是那个3D效果,简直是让我眼花缭乱,头...
android操作系统耗电-安... 哎呀,说到安卓手机,我这心里就一肚子火!每次出门前,手机电量还满格,结果没一会儿,就剩下个位数了。这...
雨田蜂蜜:承载童年记忆的甜蜜滋... 在那些细雨蒙蒙的日子里,我总是不由自主地想起家乡的那片雨田,以及那从田间飘来的蜂蜜香。那是一种无法用...
身份证号码查姓名地址,背后隐藏... 嘿,小伙伴们,今天咱们来聊聊一个有点儿神秘的话题——身份证号码查姓名地址。你有没有想过,那些冷冰冰的...
巫师3 dsound.dll在... 哎呀,朋友们,今天咱们来聊聊那个让人抓狂的dsound.dll问题。你知道的,就是那个在《巫师3》里...
android+验证身份证号码... 哎呀,今天咱们来聊聊这个有点严肃但又挺重要的话题——Android手机上怎么验证身份证号码。我知道,...
360数据恢复免费吗-360 ... 大家好,我是一个对电脑一窍不通的小白。前段时间,我不小心删了电脑里的一些重要文件,心里那个急啊,就像...
苹果7使用说明书图解-探索苹果... 大家好呀!今天我要带你们一起探索苹果7的奇妙世界,用最酷炫的方式解锁它的所有秘密!别担心,我们不需要...
win10开机启动项 命令-W... 哎呀,说到Win10开机启动项,我就一肚子火!每次开机,那屏幕就像在跟我玩捉迷藏,转啊转的,半天不见...
相机内存卡文件为空-珍贵照片离... 哎呀,真是气死我了!今天兴冲冲地打开相机,准备回味一下上个周末的欢乐时光,结果一看,我的天,那些珍贵...
苹果手机怎么快速省电-掌握这些... 哎呀呀,说到苹果手机省电,我可是有一肚子的话要说!你知道吗,每次看到手机电量从满格到红线,我的心就像...
北京朝阳医院儿科电话:希望的传... 在北京这座快节奏的都市里,每一个角落都充满了匆忙与喧嚣。但如果你细心倾听,会发现有一个声音始终温暖而...
易购分销平台:海量商品、超实惠... 大家好,我是小张,一个在街角开小店的老板。今天我要给大家聊聊我最近发现的一个超级棒的地方——易购分销...
opensuse 42.2壁纸... 嘿,亲爱的OpenSUSE爱好者们,今天咱们聊聊那些让人眼前一亮的OpenSUSE42.2壁纸!这些...
帝国 政府 模板-在宏伟帝国里... 在这个宏伟的帝国里,每一天都像是政府精心布置的一盘棋。我,一个深陷其中的小卒,感受着这场游戏的起伏与...
苹果恢复大师收费标准揭秘:基本... 大家好,今天咱们来聊聊这个让人又爱又恨的“苹果恢复大师”!你知道吗?这玩意儿简直就是苹果界的救星,但...