ในปัญหานี้ เราได้รับสตริง str และเราต้องพิมพ์ตัวอักษรทั้งหมดตามลำดับศัพท์
มาดูตัวอย่างเพื่อทำความเข้าใจปัญหากันดีกว่า −
Input: str = ‘XYZ’ Output : X XY XYZ XZ XZY Y YX YXZ YZ YZX Z ZX ZXY ZY ZYX
เพื่อแก้ปัญหานี้ เราจะพิมพ์ชุดอักขระทั้งหมดในสตริง สำหรับสิ่งนี้ เราจำเป็นต้องมีโครงสร้างข้อมูลแผนที่เพื่อจัดเก็บอักขระของสตริง สำหรับการนำไปใช้จริง เราจะต้องใช้การย้อนรอยเพื่อติดตามชุดค่าผสมทั้งหมด
ตัวอย่าง
#include <bits/stdc++.h> using namespace std; void printResult(char* result, int len); void findstringCombination(char result[], char str[], int count[],int level, int size, int length) ; void printCharCombination(string str); int main(){ string str = "ABC"; cout<<"The combination of characters of the string :\n"; printCharCombination(str); return 0; } void findstringCombination(char result[], char str[], int count[],int level, int size, int length){ if (level == size) return; for (int i = 0; i < length; i++) { if (count[i] == 0) continue; count[i]--; result[level] = str[i]; printResult(result, level); findstringCombination(result, str, count, level + 1, size, length); count[i]++; } } void printCharCombination(string str){ map<char, int> mp; for (int i = 0; i < str.size(); i++) { if (mp.find(str[i]) != mp.end()) mp[str[i]] = mp[str[i]] + 1; else mp[str[i]] = 1; } char* input = new char[mp.size()]; int* count = new int[mp.size()]; char* result = new char[str.size()]; map<char, int>::iterator it = mp.begin(); int i = 0; for (it; it != mp.end(); it++) { input[i] = it->first; count[i] = it->second; i++; } int length = mp.size(); int size = str.size(); findstringCombination(result, input, count, 0, size, length); } void printResult(char* result, int len){ for (int i = 0; i <= len; i++) cout<<result[i]; cout<<endl; }
ผลลัพธ์
การรวมกันของอักขระของสตริง −
A AB ABC AC ACB B BA BAC BC BCA C CA CAB CB CBA