เราได้รับสตริง 'str' ที่มีความยาวเท่าใดก็ได้ งานคือการจัดเรียงอักขระใหม่ในลักษณะที่ผลลัพธ์จะเป็นสตริง palindrome โดยไม่ต้องเพิ่มหรือลบอักขระออกจากสตริงอินพุตที่กำหนด สตริง Palindrome เป็นสตริงที่อักขระถูกจัดเรียงในลักษณะที่ออกเสียงเหมือนกันตั้งแต่ต้นและสุดท้าย
ให้เราดูสถานการณ์อินพุตเอาต์พุตที่หลากหลายสำหรับสิ่งนี้ -
ป้อนข้อมูล − string str ="อิทนิน"
ผลผลิต − การจัดเรียงอักขระใหม่เพื่อสร้าง palindrome ถ้าเป็นไปได้คือ:nitin
คำอธิบาย − เราได้รับตัวแปรประเภทสตริง สมมติว่า str ตอนนี้ เราจะจัดเรียงอักขระของสตริงอินพุตใหม่ในลักษณะที่จะเป็นสตริงพาลินโดรม และหากเป็นไปไม่ได้ อักขระดังกล่าวจะส่งคืน 'ไม่เป็นไปได้' ดังนั้นเอาต์พุตที่มีสตริงอินพุตที่กำหนดคือ 'nitin'
ป้อนข้อมูล − string str ="baaaba"
ผลผลิต − การจัดเรียงอักขระใหม่ให้กลายเป็น palindrome ถ้าเป็นไปได้คือ:aabbaa
คำอธิบาย − เราได้รับตัวแปรประเภทสตริง สมมติว่า str ตอนนี้ เราจะจัดเรียงอักขระของสตริงอินพุตใหม่ในลักษณะที่จะเป็นสตริงพาลินโดรม และหากไม่สามารถทำได้ อักขระนั้นจะส่งกลับ "เป็นไปไม่ได้" ดังนั้นเอาต์พุตที่มีสตริงอินพุตที่กำหนดคือ 'aabbaa'
แนวทางที่ใช้ในโปรแกรมด้านล่างมีดังนี้
-
ป้อนตัวแปรประเภทสตริง สมมติว่า str และคำนวณขนาดของสตริงและเก็บไว้ในความยาวที่ตั้งชื่อตัวแปร
-
ส่งข้อมูลไปยังฟังก์ชัน Rearrangement(str, length)
-
ภายในฟังก์ชัน การจัดเรียงใหม่ (arr, length)
-
สร้างตัวแปรเป็น 'um' ของประเภท unordered_map ที่จัดเก็บคู่ของประเภทถ่านและจำนวนเต็ม
-
ประกาศตัวแปรประเภทจำนวนเต็มเป็นผลรวมและตั้งค่าเป็น 0
-
สร้างตัวแปรประเภทอักขระเป็น 'ch' และตัวแปรประเภทสตริงเป็น str_1 และ str_2
-
เริ่มวนรอบ FOR จาก i ถึง 0 จนถึง i น้อยกว่าความยาว ภายในลูป ตั้งค่า um[str[i]] ด้วยค่าที่เพิ่มขึ้นเป็น 1
-
เริ่มวนซ้ำ FOR เพื่อวนซ้ำแผนที่ 'อืม' ภายในลูป ให้ตรวจสอบว่า it.second % 2 ไม่เท่ากับ 0 แล้วเพิ่มผลรวม 1 และตั้งค่า ch ด้วย it.first
-
ตรวจสอบว่าผลรวมมากกว่า 1 หรือผลรวม =1 AND ความยาว % 2 =0 แล้วคืนค่า 0
-
เริ่มวนซ้ำ FOR เพื่อวนซ้ำแผนที่ 'อืม' ภายในลูป ให้ตั้งค่า str(it.second / 2, it.first), str_1 เป็น str_1 + str และ str_2 เป็น str + str_2
-
ตรวจสอบ IF total =1 แล้วคืนค่า str_1 + ch + str_2 ELSE ให้คืนค่า str_1 + str_2
-
-
พิมพ์ผลลัพธ์
ตัวอย่าง
#include <bits/stdc++.h>
using namespace std;
string Rearrangement(string str, int length){
unordered_map<char, int> um;
int total = 0;
char ch;
string str_1 = "";
string str_2 = "";
for (int i = 0; i < length; i++){
um[str[i]]++;
}
for(auto it : um){
if(it.second % 2 != 0){
total++;
ch = it.first;
}
}
if(total > 1 || total == 1 && length % 2 == 0){
return 0;
}
for(auto it : um){
string str(it.second / 2, it.first);
str_1 = str_1 + str;
str_2 = str + str_2;
}
if(total == 1){
return str_1 + ch + str_2;
}
else{
return str_1 + str_2;
}
}
int main(){
string str = "itnin";
int length = str.size();
cout<<"Rearrangement of characters to form palindrome if possible is: "<<Rearrangement(str, length);
return 0;
} ผลลัพธ์
หากเรารันโค้ดด้านบน มันจะสร้างผลลัพธ์ต่อไปนี้
Rearrangement of characters to form palindrome if possible is: nitin