• java选做实验4常用集合类使用


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

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

    源代码如下:

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

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

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

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

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

    1. package first;
    2. import java.text.ParseException;
    3. import java.util.Date;
    4. import java.text.SimpleDateFormat;
    5. import java.util.*;
    6. public class first {
    7. static void countTimeDifferent(Date[]date, int num, String []times){
    8. long []time=new long [num];
    9. for(int i=0;i
    10. time[i]=date[i].getTime();//time接收date表示的时间化为毫秒后的long型数据
    11. for(int i=0;i1;i++){//num个时间那么就有num-1个时间差
    12. if(time[i]>time[i+1]){
    13. System.out.print(times[i]+"到"+times[i+1]+"的时间间隔是:");
    14. }
    15. else{
    16. System.out.print(times[i+1]+"到"+times[i]+"的时间间隔是:");
    17. }
    18. long different=Math.abs(time[i]-time[i+1]);
    19. different/=1000;//将时间差化为秒数
    20. long year,month,day,hour,minute,second;
    21. year=different/(60*60*24*365);//得到相差的年数
    22. different-=year*(60*60*24*365);
    23. month=different/(60*60*24*30);//得到相差的月数
    24. different-=month*(60*60*24*30);
    25. day=different/(60*60*24);//得到相差的天数
    26. different-=day*(60*60*24);
    27. hour=different/(60*60);//得到相差的小时数
    28. different-=hour*(60*60);
    29. minute=different/60;//得到相差的分钟数
    30. different-=minute*60;
    31. second=different;//秒数
    32. System.out.print(year+"年"+month+"月"+day+"日");
    33. System.out.println(hour+"时"+minute+"分"+second+"秒");
    34. }
    35. }
    36. public static void main(String []args){
    37. System.out.print("请输入要计算的时间差个数:");
    38. Scanner scanner=new Scanner(System.in);
    39. int num=scanner.nextInt();
    40. Date []date=new Date[num];//date用来存储日期
    41. String []times=new String[num];//times用来存储以string接收的日期
    42. for(int i=0;i
    43. String s1=scanner.next();
    44. Scanner input=new Scanner(s1);
    45. input.useDelimiter("[^0123456789]+");//除数字外的字符全为分隔符
    46. int []time=new int[6];//分别存储年、月、日、时、分、秒6位数字
    47. int count=0;//下标变量
    48. while(input.hasNext()){
    49. try{
    50. time[count++]=input.nextInt();
    51. }
    52. catch(InputMismatchException in){
    53. input.next();
    54. }
    55. }
    56. times[i]=time[0]+"年"+time[1]+"月"+time[2]+"日"+time[3]+"时"+time[4]+"分"+time[5]+"秒";//分辨输出
    57. SimpleDateFormat sdf=new SimpleDateFormat("yyyy年MM月dd日HH时mm分ss秒");//格式化
    58. try{
    59. Date da=sdf.parse(times[i]);
    60. long long_num=da.getTime();//将输入的时间化为long类型存储
    61. date[i]=new Date(long_num);//给日期初始化
    62. }
    63. catch(ParseException pa){//出现转化异常
    64. pa.printStackTrace();
    65. }
    66. input.close();
    67. }
    68. countTimeDifferent(date,num,times);
    69. scanner.close();
    70. }
    71. }

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

    1. 7
    2. 20221118121223
    3. 20231118121223
    4. 20231218121223
    5. 20231219121223
    6. 20231219111223
    7. 20231219111323
    8. 20231219111324

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

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

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

    1. private int column;//列数
    2. private int row;//行数
    3. private int [][]matrix;//矩阵数组

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

    1. public Matrix(){
    2. column=0;
    3. row=0;
    4. }
    5. public Matrix(int r,int c) {
    6. row = r;
    7. column = c;
    8. matrix = new int[row][column];
    9. }

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

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

    1. public void setMatrix(int [][]m){
    2. matrix=m;
    3. }

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

    1. public void print(){
    2. for(int i=0;i
    3. for(int j=0;j
    4. System.out.print(matrix[i][j]+" ");
    5. System.out.println();
    6. }
    7. }

    矩阵相加方法:

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

    1. public void add(Matrix matrix1){
    2. if(column!=matrix1.column||row!=matrix1.row){
    3. System.out.println("两矩阵不符合相加条件(行列数均相等),无法相加qwq");
    4. }
    5. else{
    6. Matrix matrix2=new Matrix(column,row);
    7. for(int i=0;i
    8. for(int j=0;j
    9. matrix2.matrix[i][j]=this.matrix[i][j]+matrix1.matrix[i][j];
    10. System.out.println("两矩阵相加的结果为:");
    11. matrix2.print();
    12. }
    13. }

    矩阵相乘方法:

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

    1. public void multiply(Matrix matrix1){
    2. if(column!=matrix1.row){//首先判断矩阵是否满足相乘的条件
    3. System.out.println("两矩阵不符合相乘条件(左矩阵的列数与右矩阵的行数的相等),无法相乘qwq");
    4. }
    5. else{
    6. Matrix matrix2=new Matrix(row,matrix1.column);
    7. for(int i=0;i//套用公式子求矩乘积
    8. for(int j=0;j
    9. for(int k=0;k
    10. matrix2.matrix[i][j]+=matrix[i][k]*matrix1.matrix[k][j];
    11. System.out.println("两矩阵相乘的结果为:");
    12. matrix2.print();
    13. }
    14. }

    2、main里面:

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

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

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

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

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

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

    1. try{
    2. for(int i=0;i
    3. for(int j=0;j
    4. matrix[i][j]=input.nextInt();
    5. }
    6. catch(Exception e){
    7. System.out.println("第一个矩阵输入有误:"+e);
    8. return;
    9. }
    10. Matrix matrix1=new Matrix(row1,column1);
    11. matrix1.setMatrix(matrix);

    matrix2的初始化与matrix类似

    1. System.out.print("请分别输入第二个矩阵的行数和列数");
    2. row2=scanner.nextInt();
    3. column2=scanner.nextInt();
    4. s=scanner.nextLine();//“吃掉”末尾的换行符
    5. System.out.println("请输入第二个矩阵");
    6. s=scanner.nextLine();
    7. input=new Scanner(s);
    8. input.useDelimiter("[^1234567890]+");//数字外都是分隔符
    9. matrix=new int[row2][column2];
    10. try{
    11. for(int i=0;i
    12. for(int j=0;j
    13. matrix[i][j]=input.nextInt();
    14. }
    15. catch(Exception e){
    16. System.out.println("第二个矩阵输入有误:"+e);
    17. return;
    18. }
    19. Matrix matrix2=new Matrix(row2,column2);
    20. matrix2.setMatrix(matrix);

    最后是输出

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

    测试数据:

    1. 3 2
    2. 1 2 3 4 5 6
    3. 2 3
    4. 1 2 3 4 5 6
    5. 3 3
    6. 1 2 3 4 5 6
    7. 3 3
    8. 1 2 3 4 5 6
    9. 3 2
    10. 1 2 3 4 5 6
    11. 2 3
    12. 1 2 3 4 5 6
    13. 3 3
    14. 1 2 3 4 5 6 7 8 9
    15. 3 3
    16. 1 2 3 4 5 6 7 8 9

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

  • 相关阅读:
    TSINGSEE青犀基于AI视频识别技术的平安校园安防视频监控方案
    从 12K 到 60K, 这 2023Java 研发必问高级面试题,过关斩将拿 offer
    【Linux】System V 信号量
    开发笔记 03,为什么不要问别人在做什么小产品?
    UML类图的六大关系,最佳学习理解方式
    雷达天线、信号链路、大气衰减基本概念
    流式数据湖平台Hudi核心概念一:时间线
    思科模拟器--08.三层交换机配置实验(两个交换机)--24.5.22
    图片速览 Deep Clustering for Unsupervised Learning of Visual Features
    卷积神经网络结构有哪些,卷积神经网络结构特点
  • 原文地址:https://blog.csdn.net/weixin_62431082/article/details/127914780