輸入乙個字串,已知字串中的字元是互不相同的,現在把它們任意排列,例如:"ab"字串可以排列為"aa","ab","ab","bb"
,程式設計按照字典序輸出所有的結果。
#include
using
namespace
std;
class solution
//不停的按照不同的字元遞迴下去
for (int i = 0; i < str.length(); i++)
}};
#include"1.3 字典序的所有排列.h"
void main()
//結果為 "aa","ab","ab","bb"
這類字串全排列的題目不管字元可不可以重複,一般都有乙個通用的思路,通常使用遞迴的方式不斷更改每一位上的字元,一直到遞迴到最後一位則可以直接輸出排列好的字串。而這種型別的題目有所改變的地方通常在上面**中的重點①
,應該根據題目的具體需求來改變程式。
這道題出自《程式設計之法》的1.3小節的舉一反三。
全排列演算法的字典序排列
之前在中描述了全排列演算法的遞迴解法,這裡再說一種演算法 字典序排列。字典序排列就是按照字典a z,1 9的順序給出字串的順序全排列,例如abc的全排列就是從abc一直排到cba。那麼給定乙個字串,怎麼找出恰好大於該字串的下乙個排列呢?我們考慮如下的步驟 1 假設字串為p1p2 pn,我們從後往前尋...
排列的演算法(一) 字典序演算法
從n個不同元素中取出n個元素的排列,稱為n個不同元素的全排列。可以證明,n個元素的全排列的總數是n!全排列的生成演算法就是對於給定的元素集合,用有效的方法將所有可能的全排列無重複無遺漏地列舉出來。n個不同元素的排列都可以與n個自然數1 2 n的排列一一對應,所以,這裡就以n個數字的排列為例說明排列的...
c 全排列的字典序
背景 7 3 輸出全排列 20 分 請編寫程式輸出前n個正整數的全排列 n 10 並通過9個測試用例 即n從1到9 觀察n逐步增大時程式的執行時間。輸入格式 輸入給出正整數n 10 輸出格式 輸出1到n的全排列。每種排列佔一行,數字間無空格。排列的輸出順序為字典序 輸入樣例 3輸出樣例 123132...