Check whether second string can be formed from characters of first string Last Updated : 29 Sep, 2022 Comments Improve Suggest changes Like Article Like Report Given two strings str1 and str2, check if str2 can be formed from str1 Example : Input : str1 = geekforgeeks, str2 = geeksOutput : YesHere, string2 can be formed from string1. Input : str1 = geekforgeeks, str2 = andOutput : NoHere string2 cannot be formed from string1. Input : str1 = geekforgeeks, str2 = geeeekOutput : YesHere string2 can be formed from string1as string1 contains 'e' comes 4 times instring2 which is present in string1. The idea is to count frequencies of characters of str1 in a count array. Then traverse str2 and decrease frequency of characters of str2 in the count array. If frequency of a characters becomes negative at any point, return false. Below is the implementation of above approach : C++ // CPP program to check whether second string // can be formed from first string #include <bits/stdc++.h> using namespace std; const int MAX = 256; bool canMakeStr2(string str1, string str2) { // Create a count array and count frequencies // characters in str1. int count[MAX] = {0}; for (int i = 0; i < str1.length(); i++) count[str1[i]]++; // Now traverse through str2 to check // if every character has enough counts for (int i = 0; i < str2.length(); i++) { if (count[str2[i]] == 0) return false; count[str2[i]]--; } return true; } // Driver Code int main() { string str1 = "geekforgeeks"; string str2 = "for"; if (canMakeStr2(str1, str2)) cout << "Yes"; else cout << "No"; return 0; } Java // Java program to check whether second string // can be formed from first string class GFG { static int MAX = 256; static boolean canMakeStr2(String str1, String str2) { // Create a count array and count frequencies // characters in str1. int[] count = new int[MAX]; char []str3 = str1.toCharArray(); for (int i = 0; i < str3.length; i++) count[str3[i]]++; // Now traverse through str2 to check // if every character has enough counts char []str4 = str2.toCharArray(); for (int i = 0; i < str4.length; i++) { if (count[str4[i]] == 0) return false; count[str4[i]]--; } return true; } // Driver Code static public void main(String []args) { String str1 = "geekforgeeks"; String str2 = "for"; if (canMakeStr2(str1, str2)) System.out.println("Yes"); else System.out.println("No"); } } Python3 # Python program to check whether second string # can be formed from first string def canMakeStr2(s1, s2): # Create a count array and count # frequencies characters in s1 count = {s1[i] : 0 for i in range(len(s1))} for i in range(len(s1)): count[s1[i]] += 1 # Now traverse through str2 to check # if every character has enough counts for i in range(len(s2)): if (count.get(s2[i]) == None or count[s2[i]] == 0): return False count[s2[i]] -= 1 return True # Driver Code s1 = "geekforgeeks" s2 = "for" if canMakeStr2(s1, s2): print("Yes") else: print("No") C# // C# program to check whether second string // can be formed from first string using System; class GFG { static int MAX = 256; static bool canMakeStr2(string str1, string str2) { // Create a count array and count frequencies // characters in str1. int[] count = new int[MAX]; for (int i = 0; i < str1.Length; i++) count[str1[i]]++; // Now traverse through str2 to check // if every character has enough counts for (int i = 0; i < str2.Length; i++) { if (count[str2[i]] == 0) return false; count[str2[i]]--; } return true; } // Driver Code static public void Main() { string str1 = "geekforgeeks"; string str2 = "for"; if (canMakeStr2(str1, str2)) Console.WriteLine("Yes"); else Console.WriteLine("No"); } } // This code is contributed by vt_m. PHP <?php // PHP program to check whether // second string can be formed // from first string $MAX = 256; function canMakeStr2($str1, $str2) { // Create a count array and // count frequencies characters // in str1. $count = (0); for ($i = 0; $i < strlen($str1); $i++) // Now traverse through str2 // to check if every character // has enough counts for ($i = 0; $i < strlen($str2); $i++) { if ($count[$str2[$i]] == 0) return -1; } return true; } // Driver Code $str1 = "geekforgeeks"; $str2 = "for"; if (canMakeStr2($str1, $str2)) echo "Yes"; else echo "No"; // This code is contributed by ajit ?> JavaScript <script> // Javascript program to check whether second string // can be formed from first string function canMakeStr2(str1, str2) { // Create a count array and count frequencies // characters in str1. let count = {}; // count.fill(0); for (let i = 0; i < str1.length; i++) { if (str1[i] in count) count[str1[i]]++; else count[str1[i]] = 1 } // Now traverse through str2 to check // if every character has enough counts for (let i = 0; i < str2.length; i++) { if (count[str2[i]] == 0 || !(str2[i] in count)) return false; count[str2[i]]--; } return true; } let str1 = "geekforgeeks"; let str2 = "gggeek"; if (canMakeStr2(str1, str2)) document.write("Yes"); else document.write("No"); </script> OutputYes Time Complexity: O(n+m), where n and m are the length of the given strings. Auxiliary Space: O(256), which is constant. Comment More infoAdvertise with us Next Article Check whether second string can be formed from characters of first string A anuragrawat1 Follow Improve Article Tags : Misc Strings Technical Scripter DSA Arrays frequency-counting +2 More Practice Tags : ArraysMiscStrings Similar Reads Check if characters of one string can be swapped to form other Two strings are given, we need to find whether we can form second string by swapping the character of the first string. Examples: Input : str1 = "geeksforgeeks" str2 = "geegeeksksfor" Output : YES Input : str1 = "geeksfor" str2 = "geeekfor" Output : NO First of all, we will find the length of string 6 min read Check if String formed by first and last X characters of a String is a Palindrome Given a string str and an integer X. The task is to find whether the first X characters of both string str and reversed string str are same or not. If it is equal then print true, otherwise print false. Examples: Input: str = abcdefba, X = 2Output: trueExplanation: First 2 characters of both string 5 min read Remove characters from the first string which are present in the second string Given two strings string1 and string2, remove those characters from the first string(string1) which are present in the second string(string2). Both strings are different and contain only lowercase characters.NOTE: The size of the first string is always greater than the size of the second string( |st 15+ min read Check if a string can be split into two strings with same number of K-frequent characters Given a string S and an integer K, the task is to check if it is possible to distribute these characters into two strings such that the count of characters having a frequency K in both strings is equal. If it is possible, then print a sequence consisting of 1 and 2, which denotes which character sho 11 min read Count of strings that can be formed from another string using each character at-most once Given two strings str1 and str2, the task is to print the number of times str2 can be formed using characters of str1. However, a character at any index of str1 can only be used once in the formation of str2. Examples: Input: str1 = "arajjhupoot", str2 = "rajput" Output: 1 Explanation:str2 can only 10 min read Check if both halves of the string have same set of characters Given a string of lowercase characters only, the task is to check if it is possible to split a string from the middle which will give two halves having the same characters and same frequency of each character. If the length of the given string is ODD then ignore the middle element and check for the 12 min read Check if a two character string can be made using given words Given a string of two characters and n distinct words of two characters. The task is to find if it is possible to arrange given words in such a way that the concatenated string has the given two character string as a substring. We can append a word multiple times. Examples: Input : str = "ya" words[ 6 min read Check whether two strings contain same characters in same order Given two strings s1 and s2, the task is to find whether the two strings contain the same characters that occur in the same order. For example string "Geeks" and string "Geks" contain the same characters in same order. Examples: Input: s1 = "Geeks", s2 = "Geks" Output: Yes Input: s1 = "Arnab", s2 = 9 min read Check if String can be generated by concatenating character or String itself Given a target string S consisting of lowercase alphabets, the task is to make this string by performing some operation on an empty string such that: The first operation is to append a lower case alphabet to string S and The second operation is to append a copy of S to itself. Note: The first operat 6 min read Check if a string is a scrambled form of another string Given two strings s1 and s2 of equal length, the task is to determine if s2 is a scrambled version of s1.A scrambled string is formed by recursively splitting the string into two non-empty substrings and rearranging them randomly (s = x + y or s = y + x) and then recursively scramble the two substri 15+ min read Like