java经典算法-day15

79 阅读2分钟

Offer 驾到,掘友接招!我正在参与2022春招打卡活动,点击查看活动详情

哈喽,各位小伙伴们好,我是喵手。

一、前言

正值金三银四好时节,又到了刷题月。xdm,有空的欢迎一起呀。无论你是挤公交还是坐地铁时间,随时随地皆可刷...你可以不用实操,你只需要看题思考,完后有空coding就好呀。接下来我要开启我的刷题之旅啦,喜欢的小伙伴欢迎点赞关注哦。

二、题目描述:

题目1:

将一个数组逆序输出。

题目2:

取一个7位数整数a的第4~7位数字。

三、思路分析:

题1分析:

这题其实比较简单。正常思路就是用第一个与最后一个交换,进行对称交换即可。

思路一:直接进行首位交换。

思路二:利用java工具类java.util.Collections中的自带方法Collections.reverse()

以下是java.util.Collections.reverse()方法的声明。

public static void reverse(List<?> list)

题2分析:

这题的意思就是说,取一个超过7位的数字,然后依次输出该数字的第4-7位。

其实思路有很多,最直观的就是直接使用算数运算符,依次分别进行获取。

思路一:

  • 通过算术运算符直接进行获取,把每一位值通过求余求模组合进行运算。

思路二:

  • 通过将数字转成字符串,然后对依数字字符串分别进行获取对应位置的值即可。

四、算法实现:

题1AC代码:

看到参数是一个list,而并非是数组int[],所以需要先新建一个numList集合存放原数组的元素。

/**
 * 使用.reverse()方法
 */
public static int[] reverse1(int[] nums) {

    //反转后的数组
    int[] reverseArray = new int[nums.length];
    //集合进行存放
    List numList = new ArrayList();
    for (int num : nums) {
        numList.add(num);
    }
    //调用方法逆序
    Collections.reverse(numList);
    for (int i = 0; i < nums.length; i++) {
        reverseArray[i] = (int) numList.get(i);
    }
    //返回
    return reverseArray;
}

题2AC代码:

/**
 * 获取数字的第4-7位
 */
public static void getNum1(long num) {

    //直接转成string串
    String strNum = String.valueOf(num);
    System.out.println("第4位数字为:" + strNum.charAt(3));
    System.out.println("第5位数字为:" + strNum.charAt(4));
    System.out.println("第6位数字为:" + strNum.charAt(5));
    System.out.println("第7位数字为:" + strNum.charAt(6));
}

五、总结:

综上,这两道题我是提供了多种思路供大家参考。

如果你有更好的解题思路或者想法,欢迎评论区留言告诉我哦,喵手感激不尽。

六、文末:

好啦,以上就是我这期的全部内容,如果有任何疑问,欢迎下方留言哦,咱们下期见。

... ...

学习不分先后,知识不分多少;事无巨细,当以虚心求教;三人行,必有我师焉!!!

wished for you successed !!!

---------------------------------------------------------------------

⭐️若喜欢我,就请关注我叭。

⭐️若对您有用,就请点赞叭。

⭐️若有疑问,就请评论留言告诉我叭。

---------------------------------------------------------------------