前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >脚撕LeetCode(1528)Easy

脚撕LeetCode(1528)Easy

作者头像
JathonKatu
发布2022-01-18 08:05:27
1470
发布2022-01-18 08:05:27
举报
文章被收录于专栏:JathonKatu

题目地址:https://leetcode-cn.com/problems/shuffle-string/

给你一个字符串 s 和一个 长度相同 的整数数组 indices 。请你重新排列字符串 s ,其中第 i 个字符需要移动到 indices[i] 指示的位置。返回重新排列后的字符串。

代码语言:javascript
复制
示例 1: 
输入:s = "codeleet", indices = [4,5,6,7,0,2,1,3] 
输出:"leetcode"
解释:如图所示,"codeleet" 重新排列后变为 "leetcode" 。 
https://leetcode-cn.com/problems/shuffle-string/
示例 2: 
输入:s = "abc", indices = [0,1,2] 
输出:"abc" 
解释:重新排列后,每个字符都还留在原来的位置上。 
示例 3:
输入:s = "aiohn", indices = [3,1,4,2,0] 
输出:"nihao" 
示例 4: 
输入:s = "aaiougrt", indices = [4,0,2,6,7,3,1,5] 
输出:"arigatou" 
示例 5: 
输入:s = "art", indices = [1,0,2] 
输出:"rat" 
https://leetcode-cn.com/problems/shuffle-string/
提示: 
s.length == indices.length == n 
1 <= n <= 100 
s 仅包含小写英文字母。 
0 <= indices[i] <n 
indices 的所有的值都是唯一的(也就是说,indices 是整数 0 到 n - 1 形成的一组排列)。

https://leetcode-cn.com/problems/shuffle-string/

这道题的大概思路就是,s字符串里面存放着杂乱无章的字符,而indices中存放的是s中对应位置的字符实际应该存在的位置。

一、爆破法:

我的爆破法的思路是,创建一个char数组,然后将s的内容遍历存放到char数组中指定的位置,然后new String(char[])返回。

执行结果如下:

399 / 399 个通过测试用例

状态:通过

执行用时: 1 ms

内存消耗: 38.3 MB

代码语言:javascript
复制
public String restoreStringMe(String s, int[] indices) {
    char[] ans = new char[s.length()];
    for (int i = 0; i < s.length(); i++) {
        ans[indices[i]] = s.charAt(i);
    }
    return new String(ans);
}

答案和官方答案一样。虽然时间是100%了,但是内存还是80%,折腾星人永不言败,我决定试试反射(虽然我知道可能真的会很垃圾hhh)

最终答案确实很垃圾,用的反射修改String的值,但是至少我们试过。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2021-06-07,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 JathonKatu 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档