反转字符串、反转字符串中的元音字母、两个数组的交集,springboot工作原理面试

小编菜解

public static String reverseVowels(String s) {

List list = new ArrayList() {{

add(‘a’);

add(‘e’);

add(‘i’);

add(‘o’);

add(‘u’);

}};

char[] chars = s.toCharArray();

int lg = s.length();

int right = s.length();

//遍历字符串前半段,如果是元音,则寻找右半段的最后一个元音,然后交换。

//如果不是则不做处理。

for (int left = 0; left < lg / 2; left++) {

char e = 0;

if (list.contains(chars[left])) {

//寻找右半段的最后一个元音

for (int j = right - 1; j >= 0; j–) {

e = chars[j];

if (list.contains(e)) {

right = j;

break;

}

}

//交换最左元音和最右元音

char temp = chars[left];

chars[left] = e;

chars[right] = temp;

}

}

return new String(chars);

}

感觉list这块有点麻烦。

小编菜解改进版

public static String reverseVowels(String s) {

String const_A_U = “aeiouAEIOU”;

char[] chars = s.toCharArray();

int lg = s.length();

int right = s.length();

//遍历字符串前半段,如果是元音,则寻找右半段的最后一个元音,然后交换。

//如果不是则不做处理。

for (int left = 0; left < lg / 2; left++) {

char e = 0;

if (const_A_U.indexOf(chars[left])>=0) {

//寻找右半段的最后一个元音

for (int j = right - 1; j >= 0; j–) {

e = chars[j];

if (const_A_U.indexOf(e)>=0) {

right = j;

break;

}

}

//交换最左元音和最右元音

char temp = chars[left];

chars[left] = e;

chars[right] = temp;

}

}

return new String(chars);

}

虽然有点麻烦,但好赖思路清晰,感觉可以提交了,但是提示错误。Why?

反转字符串、反转字符串中的元音字母、两个数组的交集,springboot工作原理面试

大佬指点*

public static String reverseVowels(String s) {

String const_AE = “aeiouAEIOU”;

char[] chars = s.toCharArray();

int lg = s.length();

int left = 0;

int right = lg - 1;

//遍历字符串前半段,如果是元音,则寻找右半段的最后一个元音,然后交换。

//如果不是则不做处理。

while (left < right) {

//如果不是元音

while (left < lg && const_AE.indexOf(chars[left]) < 0) {

++left;

}

//如果不是元音

while (right > 0 && const_AE.indexOf(chars[right]) < 0) {

–right;

}

if (left < right) {

char temp = chars[left];

chars[left] = chars[right];

chars[right] = temp;

++left;

–right;

}

}

re

《一线大厂Java面试题解析+后端开发学习笔记+最新架构讲解视频+实战项目源码讲义》

【docs.qq.com/doc/DSmxTbFJ1cmN1R2dB】 完整内容开源分享

turn new String(chars);

}

大佬的思路和我的是一样的,但是利用双指针进行操作明显比我的前半段后半段,更加直观简洁。

3、LeetCode 349.两个数组的交集


题目

给定两个数组,编写一个函数来计算它们的交集。

小编菜解

public static int[] intersection(int[] nums1, int[] nums2) {

Set set = new HashSet<>();

for (int i = 0; i < nums1.length; i++) {

for (int j = 0; j < nums2.length; j++) {

if (nums1[i] == nums2[j]){

set.add(nums1[i]);

}

}

}

int[] arr = new int[set.size()];

int i = 0;

for (int s : set) {

arr[i] = s;

i++;

}

return arr;

}

虽然解决了问题,提交成功了,但是总感觉,菜的令人发指,不是很满意。

小编菜解的时间复杂度是O(mn),也就是传统意义上的暴力算法,不建议采用。

思想及算法

如果使用哈希集合存储元素,则可以在 O(1)O(1) 的时间内判断一个元素是否在集合中,从而降低时间复杂度。

首先使用两个集合分别存储两个数组中的元素,然后遍历较小的集合,判断其中的每个元素是否在另一个集合中,如果元素也在另一个集合中,则将该元素添加到返回值。该方法的时间复杂度可以降低到 O(m+n)O(m+n)。

大佬指点*

public static int[] intersection(int[] nums1, int[] nums2) {

Set set1 = new HashSet<>();

Set set2 = new HashSet<>();

for (int i = 0; i < nums1.length; i++) {

set1.add(nums1[i]);

}

for (int i = 0; i < nums2.length; i++) {

set2.add(nums2[i]);

}

return getIntersection(set1, set2);

}

public static int[] getIntersection(Set set1, Set set2) {

if (set1.size()>set2.size()){

return getIntersection(set2,set1);

}

Set set = new HashSet<>();

for (Integer x : set1){

if (set2.contains(x)){

set.add(x);

}

}

int[] ret = new int[set.size()];

int i = 0;

for (Integer x : set){

ret[i++] = x;

}

return ret;

}

代码貌似更繁琐了,但重要的是这个思想,尽量避免多重for循环。

时间复杂度不一样,执行用时提升显著。

反转字符串、反转字符串中的元音字母、两个数组的交集,springboot工作原理面试

推荐阅读

【100天算法入门 - 每日三题 - Day12】Nim游戏、3的幂、4的幂

【100天算法入门 - 每日三题 - Day11】丢失的数字、移动零、单词规律

【100天算法入门 - 每日三题 - Day10】二叉树的所有路径、各位相加、丑数

【100天算法入门 - 每日三题 - Day9】汇总区间、2的幂、有效的字母异位词

上一篇:为什么overflow:hidden能达到清除浮动的目的?


下一篇:CSS 的overflow:hidden (清除浮动)