任意の長さの文字列「str」を取得します。タスクは、指定された入力文字列に文字を追加または削除せずに、回文文字列となる最大の部分文字列が存在するように文字を再配置することです。回文文字列は、最初から最後まで同じように聞こえるように配置された文字列です。
Input- string str = "itnin"
Output - 回文部分文字列の数が最大になるように文字列を並べ替えます: iinnt。
説明- 文字列型の変数、たとえば str を取得します。次に、入力文字列の文字を再配置して最大の回文文字列にし、それが不可能な場合は「NOT POSSIBLE」を返します。したがって、入力文字列を指定した場合の出力は「iinnt」になります。入力- string str = "abaaaabb"
出力 - 回文部分文字列の数を最大化するために文字列を並べ替えると、aaaaabbb となります。
説明 - str などの文字列型変数を与えます。次に、入力文字列の文字を再配置して最大の回文文字列にし、それが不可能な場合は「NOT POSSIBLE」を返します。したがって、指定された入力文字列の出力は aaaaaabbb'
文字列変数を入力します。 str と入力して、文字列のサイズを取得し、それを length という名前の変数に格納します。
データを関数 Rearr_string(str, length) に渡します。
関数 Rearr_string(str, length) 内
#include <bits/stdc++.h> using namespace std; string Rearr_string(string str, int length){ int arr[26] = { 0 }; string temp = ""; for(int i = 0; i < length; i++){ arr[str[i] - 'a']++; } for(int i = 0; i < 26; i++){ for(int j = 0; j < arr[i]; j++){ temp = temp + (char)(97 + i); } } return temp; } int main(){ string str = "itinn"; int length = str.length(); cout<<"Rearrangement of the string to maximize the number of palindromic substrings is: "<<Rearr_string(str, length); return 0; }出力上記のコードを実行すると、次の出力が生成されます
Rearrangement of the string to maximize the number of palindromic substrings is: iinnt
以上がC++ で文字列を再配置して回文部分文字列の数を最大化するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。