w3resource

JavaScript: Rearrange characters of a given string in such way that it will become equal to another given string

JavaScript Basic: Exercise-99 with Solution

Check if String Can Rearrange to Match Another

Write a JavaScript program to check whether it is possible to rearrange the characters of a given string. This is in such a way that it will become equal to another given string.

Sample Solution:

JavaScript Code:

// Function to check if characters of str1 can be rearranged to form str2
function rearrangement_characters(str1, str2) {
  // Splitting the strings into arrays of characters
  var first_set = str1.split(''), // Array for characters of str1
      second_set = str2.split(''), // Array for characters of str2
      result = true; // Variable to store the result of rearrangement check

  // Sorting the character arrays in ascending order
  first_set.sort();
  second_set.sort();

  // Loop through the arrays to compare each character position
  for (var i = 0; i < Math.max(first_set.length, second_set.length); i++) {
    // Check if characters at the same position in both arrays are different
    if (first_set[i] !== second_set[i]) {
      result = false; // Set result to false if characters differ
    }
  }

  return result; // Return the final result of rearrangement check
}

// Testing the function with sample strings
console.log(rearrangement_characters("xyz", "zyx")); // Example usage
console.log(rearrangement_characters("xyz", "zyp")); // Example usage 

Output:

true
false

Live Demo:

See the Pen javascript-basic-exercise-99 by w3resource (@w3resource) on CodePen.


Flowchart:

Flowchart: JavaScript - Rearrange characters of a given string in such way that it will become equal to another given string

ES6 Version:

// Function to check if two strings can be rearranged to form each other
const rearrangement_characters = (str1, str2) => {
  // Splitting both strings into arrays of characters
  let first_set = str1.split(''); // Array from first string
  let second_set = str2.split(''); // Array from second string
  let result = true; // Initializing result as true

  // Sorting both arrays
  first_set.sort();
  second_set.sort();

  // Looping through the arrays to compare elements
  for (let i = 0; i < Math.max(first_set.length, second_set.length); i++) {
    if (first_set[i] !== second_set[i]) {
      result = false; // If any character at the same index is different, set result to false
    }
  }

  return result; // Return the result
}

console.log(rearrangement_characters("xyz", "zyx")); // Example usage
console.log(rearrangement_characters("xyz", "zyp")); // Example usage

Improve this sample solution and post your code through Disqus.

Previous: JavaScript program to switch case of the minimum possible number of letters to make a given string written in the upper case or in the lower case.
Next: JavaScript program to check if there is at least one element which occurs in two given sorted arrays of integers.

What is the difficulty level of this exercise?

Test your Programming skills with w3resource's quiz.



Follow us on Facebook and Twitter for latest update.