Shuffle String leetcode solution in c++
You are given a string s and an integer array indices of the same length. The string s will be shuffled such that the character at the ith position moves to indices[i] in the shuffled string.
Return the shuffled string.
Example 1:

Input: s = "codeleet", indices = [4,5,6,7,0,2,1,3]
Output: "leetcode"
Explanation: As shown, "codeleet" becomes "leetcode" after shuffling.
Example 2:
Input: s = "abc", indices = [0,1,2]
Output: "abc"
Explanation: After shuffling, each character remains in its position.
Constraints:
s.length == indices.length == n1 <= n <= 100sconsists of only lowercase English letters.0 <= indices[i] < n- All values of
indicesare unique.
solution<1>:
Runtime: 19 ms, faster than 20.85% of C++ online submissions for Shuffle String.
Memory Usage: 15.2 MB, less than 78.13% of C++ online submissions for Shuffle String.
- class Solution {
- public:
- string restoreString(string s, vector<int>& indices) {
- string ans=s;
- for (int i = 0; i < indices.size(); i++)
- {
- ans[indices[i]]=s[i];
- }
- return ans;
- }
- };
solution<2>:
Runtime: 25 ms, faster than 7.50% of C++ online submissions for Shuffle String.
Memory Usage: 15.3 MB, less than 42.34% of C++ online submissions for Shuffle String.
- class Solution {
public:
string restoreString(string s, vector<int>& indices) {
string ans;
for (int i = 0; i < indices.size(); i++)
{
for (int j = 0; j < indices.size(); j++)
{
if (i == indices[j])
{
ans += s[j];
}
}
}
return ans;
}
};

No comments:
Post a Comment