日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 人文社科 > 生活经验 >内容正文

生活经验

字符串全排列的问题 python和c语言实现

發(fā)布時(shí)間:2023/11/28 生活经验 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 字符串全排列的问题 python和c语言实现 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

前言

這是一個(gè)的經(jīng)典的問(wèn)題
設(shè)計(jì)一個(gè)算法,輸出一個(gè)字符串字符的全排列。
比如,String = “abc”
輸出是"abc",“bac”,“cab”,“bca”,“cba”,“acb”

解法

從集合依次選出每一個(gè)元素,作為排列的第一個(gè)元素,然后對(duì)剩余的元素進(jìn)行全排列,如此遞歸處理;
比如:首先我要打印abc的全排列,就是第一步把a(bǔ) 和bc交換(得到bac,cab),這需要一個(gè)for循環(huán),循環(huán)里面有一個(gè)swap,交換之后就相當(dāng)于不管第一步了,進(jìn)入下一步遞歸,所以跟一個(gè)遞歸函數(shù), 完成遞歸之后把交換的換回來(lái),變成原來(lái)的字串

abc 為例子:
1. 固定a, 求后面bc的全排列: abc, acb。 求完后,a 和 b交換; 得到bac,開(kāi)始第二輪
2. 固定b, 求后面ac的全排列: bac, bca。 求完后,b 和 c交換; 得到cab,開(kāi)始第三輪
3. 固定c, 求后面ba的全排列: cab, cba即遞歸樹(shù): str:   a         b         cab ac       ba bc          ca cbresult:     abc acb      bac bca          cab cba

大概情況如下

代碼

c語(yǔ)言實(shí)現(xiàn)

#include <stdio.h>
#include <string.h>
#include <stdlib.h>void swap(char *s, int i, int j)
{char temp = s[i];s[i] = s[j];s[j] = temp;
}void permutation(char *s, int from, int to)
{if (to <= 1){return;}if (from == to){printf("%s\n", s);}else{for (int i=from; i <= to; i++){swap(s, i, from);permutation(s, from + 1, to);swap(s, from, i);}}}int main()
{char s[] = "123";permutation(s, 0, strlen(s) - 1);return 0;
}

python實(shí)現(xiàn)

def perm(s=''):if len(s) <= 1:return [s]sl = []for i in range(len(s)):for j in perm(s[0:i] + s[i + 1:]):sl.append(s[i] + j)return slprint(perm("123"))

相似題目

leetcode中有一題很相似的題目 leetcode 567. Permutation in String

參考

https://segmentfault.com/a/1190000002710424#articleHeader0

總結(jié)

以上是生活随笔為你收集整理的字符串全排列的问题 python和c语言实现的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。