java经典算法-day15
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 !!!
---------------------------------------------------------------------
⭐️若喜欢我,就请关注我叭。
⭐️若对您有用,就请点赞叭。
⭐️若有疑问,就请评论留言告诉我叭。
---------------------------------------------------------------------
- 点赞
- 收藏
- 关注作者
评论(0)